导入附近这个函数
getDistance.sql
内容如下:
-- ----------------------------
-- Function structure for getDistance
-- ----------------------------
DROP FUNCTION IF EXISTS `getDistance`;
delimiter ;;
CREATE DEFINER=`phonelive`@`%` FUNCTION `getDistance`(lat1 FLOAT, lon1 FLOAT, lat2 FLOAT, lon2 FLOAT) RETURNS float
DETERMINISTIC
BEGIN
RETURN ROUND(6378.138 * 2 * ASIN(SQRT(POW(SIN((lat1 * PI() / 180 - lat2 * PI() / 180) / 2), 2)
+ COS(lat1 * PI() / 180) * COS(lat2 * PI() / 180)
* POW(SIN(( lon1 * PI() / 180 - lon2 * PI() / 180 ) / 2),2))),2);
END
;;
delimiter ;
SET FOREIGN_KEY_CHECKS = 1;
注意:
内容中的phonelive是对应用户名,比如您的用户名live,CREATE DEFINER=`live`@`%` FUNCTION
五、web站点搭建
在oneinstack目录下添加虚拟机
cd ~/oneinstack
./vhost.sh
选项选择
1.选择1 ,Use HTTP Only
2.然后输入域名
3.输入网站的文件目录,直接回车就行
4.然后添加其他域名,有的话就输入 y ,没有就输入 n
5.是否添加防盗链,输入n
Do you want to add hotlink protection? [y/n]: n
6.Allow Rewrite rule? [y/n]: y
7.输入 y ,开启日志
Allow Nginx/Tengine/OpenResty access_log? [y/n]: y
8.Allow Rewrite rule? [y/n]: y
Please input the rewrite of programme :
wordpress,opencart,magento2,drupal,joomla,laravel,thinkphp,discuz,typecho,ecshop rewrite was exist.
(Default rewrite: other): thinkphp
nginx thinkphp 静态化
1、修改/usr/local/nginx/conf/rewrite/thinkphp.conf,
vim /usr/local/nginx/conf/rewrite/thinkphp.conf
文件内容如下;
location / {
if (!-e $request_filename) {
rewrite ^(.*)$ /index.php?s=$1 last;
break;
}
}
修改为
location / {
if (!-e $request_filename) {
rewrite ^/([0-9]+)$ /index.php?m=Show&a=index&roomnum=$1 last;
#rewrite ^(.*)$ /index.php?s=$1 last;
rewrite ^(.*)$ /index.php?s=$1 last;
break;
}
}
2、然后创建pathinfo.conf⽂文件
touch /usr/local/nginx/conf/pathinfo.conf
vim /usr/local/nginx/conf/pathinfo.conf
然后输入以下内容并保存
set $real_script_name $fastcgi_script_name;
if ($fastcgi_script_name ~ "(.+?\.php)(/.*)") {
set $real_script_name $1;
set $path_info $2;
}
fastcgi_param SCRIPT_FILENAME $document_root$real_script_name;
fastcgi_param SCRIPT_NAME $real_script_name;
fastcgi_param PATH_INFO $path_info;
3、然后编辑 /usr/local/nginx/conf/vhost/您的域名.conf 文件,
vim /usr/local/nginx/conf/vhost/您的域名.conf
编辑文件如下.
location ~ \.php {
#fastcgi_pass remote_php_ip:9000;
fastcgi_pass unix:/dev/shm/php-cgi.sock;
fastcgi_index index.php;
# include fastcgi_params;
include fastcgi.conf;
}
在include fastcgi.conf; 下⾯面加入一句
include pathinfo.conf;
然后修改/usr/local/php/etc/php.ini,搜索cgi.fix_pathinfo.把值从0改成1.
vim /usr/local/php/etc/php.ini
cgi.fix_pathinfo=1
部署直播程序
1.将代码包里面的web文件夹中的东西拷贝到网站根目录。
举例说明:
假设您的站点为: www.abc.com
mv /root/web/data/wwwroot/livenew.yunbaozb.com/* /data/wwwroot/www.abc.com/
//改变读写权限
chmod -R 775 /data/wwwroot/www.abc.com/
//改变所属者和所属组
chown -R www:www /data/wwwroot/www.abc.com
2.还需修改几个文件:
<1>(web)/api/Config/app.php
'REDIS_HOST' => "redis地址",
'REDIS_AUTH' => "redis密码",
REDIS_PORT'=>"6379"
/**
* 七⽜相关配置
*/
'Qiniu' => array(
//统⼀的key
'accessKey' => '七⽜accessKey',
'secretKey' => '七⽜secretKey',
//⾃定义配置的空间
'space_bucket' => '七⽜空间名',
'space_host' => '七⽜上传地址',
),
/**
* 本地上传
*/
'UCloudEngine' => 'local',
/**
* 本地存储相关配置( UCloudEngine为local时的配置)
*/
'UCloud' => array(
//对应的⽂件路径
'host' => 'http://域名/api/public/upload'
)
<2>web/api/Config/dbs.php
'servers' => array(
'db_appapi' => array( //服务器标
记
'host' => '数据库地址', //数据库域名
'name' => '数据库名', //数据库名字
'user' => '数据库⽤户名', //数据库⽤户名
'password' => '数据库密码', //数据库密码
'port' => '数据库端⼝号', //数据库端⼝
'charset' => '数据库编码', //数据库字符集
),
),
<3>web/data/conf/db.php
return array(
'DB_TYPE' => 'mysql',
'DB_HOST' => '数据库地址',
'DB_NAME' => '数据库名称',
'DB_USER' => '数据库账户',
'DB_PWD' => '数据库密码',
'DB_PORT' => '数据库端⼝',
'DB_PREFIX' => 'cmf_',
/* redis */
'REDIS_HOST' => "redis地址",
'REDIS_AUTH' => "redis密码",
//密钥
"AUTHCODE" => 'rCt52pF2cnnKNB3Hkp',
//cookies
"COOKIE_PREFIX" => 'AJ1sOD_',
);
<4>web/alipayapp/notifyurl.php
$link = mysql_connect("数据库地址","数据库⽤户","数据库密码");
if($link){
mysql_select_db("数据库名",$link);
<5>web/wxpay/pay/notify_jsapi.php
$link = new mysqli("数据库地址","数据库⽤户","数据库密码","数据库名");
$link = mysql_connect("数据库地址","数据库⽤户","数据库密码");
<6>web/wxshare/Application/Common/Conf/config.php
/* 数据库配置 */
'DB_TYPE' => 'mysqli', // 数据库类型
'DB_HOST' => '数据库地址', // 服务器地址
'DB_NAME' => '数据库名', // 数据库名
'DB_USER' => '数据库⽤户', // ⽤户名
'DB_PWD' => '数据库密码', // 密码
'DB_PORT' => '数据库端⼝', // 端⼝
'DB_PREFIX' => 'cmf_', // 数据库表前缀
'REDIS_HOST'=>'redis地址',
'REDIS_AUTH'=>'redis密码',
服务重启
注释掉
/usr/local/php/etc/php.d/02-opcache.ini
这个PHP缓存,开发测试阶段需要关闭否则会影响问题的修改和测试偏差。
清理掉web缓存
web/data/runtime/目录下的文件清空
service mysqld restart
service php-fpm restart
systemctl restart redis-server
systemctl restart nginx
六、nodejs部署
1.下载nvm一键安装脚本
curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.1/install.sh | bash
2.然后查看~/.zshrc文件,会看到入如下几⾏
//查看zshrc文件中是否添加
cat ~/.zshrc
//若没有,则手动添加
vim ~/.zshrc
//添加内容
export NVM_DIR="$HOME/.nvm"
[ -s "$NVM_DIR/nvm.sh" ] && . "$NVM_DIR/nvm.sh"
3.重新载入配置文件
source ~/.zshrc
4.然后安装nodejs
nvm install v6.10.2
5.然后使用安装的nodejs
nvm use v6.10.2
6.输入如下命令,如果返回的是版本号,就说明nodejs安装成功
node -v
7.然后安装cnpm
==注:只有国内服务器,才安装cnpm,执行下面的命令。国外服务器跳过。==
npm install -g cnpm --registry=https://registry.npm.taobao.org
8.然后安装pm2
cnpm install pm2 -g
9.安装nodejs拓展块
删除 /data/wwwroot/www.abc.com(自己创建的站点)/LiveNewIM/node_modules
cd /data/wwwroot/www.abc.com(自己创建的站点)/LiveNewIM
rm -rf node_modules
//推荐国外服务器使用
npm install
cpm install md5-node
cpm install node-schedule
或者
//国内服务器使用命令
cnpm install
cnpm install md5-node
cnpm install node-schedule
10.修改配置文件,将LiveNewIM目录下的config.js和exposure.js文件里面的信息修改为自己的,
cd /data/wwwroot/www.abc.com(新建的站点)/LiveNewIM
vim config.js
内容如下:
'REDISHOST' : 'redis地址',
'REDISPASS' : 'redis密码',
'REDISPORT' : '6379',
'TOKEN' : '1234567',
'WEBADDRESS': 'http://www.abc.com(自己的域名)/api/public/'
vim exposure.js
内容如下:
var site='http://www.abc.com(自己的网站域名)';
11.然后,启动nodejs程序
pm2 start s1.js --watch
pm2 start exposure.js --watch
12.保存pm2启动信息
pm2 save
13.设置开机启动
pm2 startup
七、后台信息配置需要修改的地方
1.系统设置--->公共配置--->网站信息,修改为你自己的域名http://www.abc.com