TeamTalk安装部署手册

时间:2022-05-05 07:12:27

TeamTalk安装部署手册


一、部署环境

操作系统:CentOS 7 X64(由于gcc版本问题,官方推荐centos7),

CPU2

内存:1024M

硬盘:8G

虚拟机:VirtualBox4.3.28

用户:root


二、编译依赖环境

###编译环境

部署前须安装:gccgcc-c++zipunzipwget、net-tools.x86_64

TeamTalk编译需要依赖一些最新的c++标准,建议使用CentOS7.0,如果使用的是CentOS6.x,需要将g++版本升至支持c++11特性,升级脚本可以使用:TeamTalk-master\auto_setup\gcc_setup.sh


###第三方库

TeamTalk使用了许多第三方库,包括protobuf,hiredis,mariadb(mysql),log4cxx等等,在第一次编译TeamTalk之前,建议先执行TeamTalk-master\server\src下的:

protobuf:make_protobuf.sh

hiredis:make_hiredis.sh

mariadb:make_mariadb.sh

log4cxx:make_log4cxx.sh

这些脚本执行完后会自动将头文件和库文件拷贝至指定的目录

注:以上脚本为一键部署脚本,想要一步步手动部署可参考网上资料:

http://www.bluefoxah.org/teamtalk/new_tt_deploy.html

若安装MariaDB*.rpm时出现错误,可自行安装MariaDBmariadb-devel.x86_64


三、编译协议文件

所有的协议文件在pb目录下,其中有create.sh以及sync.sh两个shell脚本。

create.sh的作用是使用protoc将协议文件转化成相应语言的源码。

sync.sh是将生成的源码拷贝到server的目录下。

注:运行以上脚本时要设置环境变量:

exportPATH=/root/TeamTalk-master/server/src/protobuf/bin:$PATH


四、编译服务端

当以上步骤都完成后,可以使用TeamTalk-master\server\src下的"./build.shversion 1"编译整个TeamTalk工程,一旦编译完成,会在上级目录生成im_server_x.tar.gz包。


五、安装说明

TeamTalk整套服务提供模块部署脚本和一键部署方案,主要模块有NGINX,PHP,MARIADB(MYSQL),REDIS,IM_WEB,IM_SERVER,其中IM_WEB,IM_SERVER为自主开发模块,其余均为开源解决方案,一键部署在auto_setup目录下:

注:

TeamTalk-master\server\im_server_x.tar.gz拷贝至TeamTalk-master\auto_setup\im_server

TeamTalk-master\php更名为tt并打包压缩拷贝至TeamTalk-master\auto_setup\im_web,否则会报如下错误:unzip: cannot find or open tt.zip, tt.zip.zip or tt.zip.ZIP

setup.sh是部署总入口,会分别调用二级目录下的setup.sh执行安装部署过程。


###NGINX:

无需改动


###PHP:

conf目录下包含两个配置文件php-fpm.conf php.ini,可以自行进行优化配置,也可以选择不改动这两个文件


###MARIADB(MYSQL):

在安装脚本setup.sh中默认设置了mysqlroot用户的初始密码为12345,在安装mariadb的过程中,会提示输入密码,如果想用自定义密码,需要修改“MYSQL_PASSWORD=12345”对密码进行设置保持一致,一旦对密码进行更改,需要同时在IM_WEBIM_SERVER中进行更改,详见IM_WEBIM_SERVER配置说明。

如果使用的是已存在的mariadb(mysql),可以直接使用"mysql-u $USER -p$PASSWORD < ttopen.sql"进行库与表的创建。


###REDIS:

conf目录下包含了redis.conf的配置文件,可以自行进行优化配置,也可以选择不改动这个文件使用默认配置。

建议对redis进行主从配置,避免redis的重启导致数据紊乱。

###IM_WEB:

conf目录下包含了config.php,database.php, im.com.conf三个配置文件,其中im.com.confNGINX所需要的配置文件,建议不改动

config.php文件主要配置了msfs服务器的地址,修改$config['msfs_url']参数即可

dababase.php文件主要配置了链接MARIADB所需要的参数,根据自己的需求修改'hostname','username','password'这三个参数。

如果使用的是现有的nginx+php环境,可以修改setup.sh中的PHP_WEB_SETUP_PATHnginx放置web代码的路径,

并且将PHP_NGINX_CONF_PATH修改为nginx配置文件的路径然后执行setup.sh脚本即可


###IM_SERVER:

IM_SERVER下共有8种服务器,所以也需要对这些服务器进行分别配置


1.LOGIN_SERVER:

ClientListenIP为提供给Client端监听的本地地址,走的是pb协议

HttpListenIP为提供给Client端监听的http协议本地地址(功能与ClientListenIP一样)

MsgServerListenIP为提供给MsgServer端监听的本地地址

msfs为提供客户端上传下载图片使用的msfs地址

discoverymac,ios,android客户端中“发现”所使用的地址,此处地址填写的是php后台的地址

2.MSG_SERVER:

ListenIP为本机监听的IP,用于Client端的消息收发;

DBServerIP用于链接DB_PROXY,此处至少填两个数据库地址,也可以是同一个实例

LoginServerIP用于链接LoginServer

RouteServerIP用于链接RouteServer

FileServerIP用于链接FileServer

PushServerIP用于链接PushServer

IpAddr填写的是Client端可以直接访问的地址,对于需要公网访问的情况下,如果是路由器映射,则需要填路由器映射在公网上的地址;此处需要填写两个Client端可以访问的地址,如果只有一个,则填写相同的地址即可

aesKeymsg_server用于消息解密使用,与各个客户端保持一致


3.ROUTE_SERVER:

根据说明配置需要监听的对应IPPort即可


4.FILE_SERVER:

AddressClient端可以直接可以访问的IP地址,对于需要公网访问的情况下,如果是路由器映射,则需要填路由器映射在公网上的地址


5.MSFS_SERVER:

ListenIPPort填写的是监听的本地IP,BaseDir为默认保存图片文件的路径,如有必要可以更改


6.DB_PROXY_SERVER

在安装配置脚本setup.sh,DB_PROXY的默认监听Port设置为10600,如果被更改需要同时对IM_SERVER中其他服务器的配置进行更改,详见MSG_SERVER,HTTP_MSG_SERVER配置说明;

对于mariadbredis的配置可以根据自己的mysql,redis进行设置


7.HTTP_MSG_SERVER

ListenIP为本地监听的地址,供php后台使用

DBServerIP用于链接DB_PROXY,此处至少填两个数据库地址,也可以是同一个实例

RouteServerIP用于链接RouteServer


8.PUSH_SERVER

ListenIP为本地监听的地址

CertPath,KeyPath,KeyPassword,SandBox为苹果apns服务所需要参数


###一键部署:

一台未安装过的NGINX,PHP,MySQL,REDIS,并且OSCentOS6.X或者7.X,在安装之前可以先执行"setup.shcheck"命令进行上述环境的检查。检查通过后对各个模块进行一些配置文件的设置,其中主要设置的为IM_SERVER中的几个服务器地址设置,设置完成后运行"setup.shinstall"


###模块部署:

TeamTalk的各模块支持安装到不同的服务器上,所以部署可以根据自己的需要进行模块安装,主要修改的地方即为上述各个模块中的IP地址设置。根据自己的网络拓扑在conf文件夹下的各个配置文件中预先设置正确的IP地址,然后执行模块内的"setupinstall"即可



6.常见问题

###设置数据库远程连接访问

予任何主机访问数据的权限:

GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '12345' WITH GRANT OPTION;

修改生效:

FLUSH PRIVILEGES;


###CentOS7关闭防火墙

关闭一个服务:

systemctl stop firewalld.service

在开机时禁用一个服务:

systemctl disable firewalld.service


###关闭selinux否则浏览器访问不了

永久关闭配置:

sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config

临时关闭selinux

setenforce 0