TeamTalk安装部署手册

2024-04-11 03:32
文章标签 部署 安装 手册 teamtalk

本文主要是介绍TeamTalk安装部署手册,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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.常见问题

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

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

授予*。*到'root'@'%'授予所有特权* 12345'授予选项;

修改生效:

FLUSH PRIVILEGES;


### CentOS7关闭防火墙

关闭一个服务:

systemctl停止firewalld.service

在开机时禁用一个服务:

systemctl禁用firewalld.service


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

永久关闭配置:

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

临时关闭selinux

setenforce 0

这篇关于TeamTalk安装部署手册的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/892958

相关文章

闲置电脑也能活出第二春?鲁大师AiNAS让你动动手指就能轻松部署

对于大多数人而言,在这个“数据爆炸”的时代或多或少都遇到过存储告急的情况,这使得“存储焦虑”不再是个别现象,而将会是随着软件的不断臃肿而越来越普遍的情况。从不少手机厂商都开始将存储上限提升至1TB可以见得,我们似乎正处在互联网信息飞速增长的阶段,对于存储的需求也将会不断扩大。对于苹果用户而言,这一问题愈发严峻,毕竟512GB和1TB版本的iPhone可不是人人都消费得起的,因此成熟的外置存储方案开

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

Centos7安装Mongodb4

1、下载源码包 curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-4.2.1.tgz 2、解压 放到 /usr/local/ 目录下 tar -zxvf mongodb-linux-x86_64-rhel70-4.2.1.tgzmv mongodb-linux-x86_64-rhel70-4.2.1/

Centos7安装JDK1.8保姆版

工欲善其事,必先利其器。这句话同样适用于学习Java编程。在开始Java的学习旅程之前,我们必须首先配置好适合的开发环境。 通过事先准备好这些工具和配置,我们可以避免在学习过程中遇到因环境问题导致的代码异常或错误。一个稳定、高效的开发环境能够让我们更加专注于代码的学习和编写,提升学习效率,减少不必要的困扰和挫折感。因此,在学习Java之初,投入一些时间和精力来配置好开发环境是非常值得的。这将为我

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

安装nodejs环境

本文介绍了如何通过nvm(NodeVersionManager)安装和管理Node.js及npm的不同版本,包括下载安装脚本、检查版本并安装特定版本的方法。 1、安装nvm curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.0/install.sh | bash 2、查看nvm版本 nvm --version 3、安装

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

SWAP作物生长模型安装教程、数据制备、敏感性分析、气候变化影响、R模型敏感性分析与贝叶斯优化、Fortran源代码分析、气候数据降尺度与变化影响分析

查看原文>>>全流程SWAP农业模型数据制备、敏感性分析及气候变化影响实践技术应用 SWAP模型是由荷兰瓦赫宁根大学开发的先进农作物模型,它综合考虑了土壤-水分-大气以及植被间的相互作用;是一种描述作物生长过程的一种机理性作物生长模型。它不但运用Richard方程,使其能够精确的模拟土壤中水分的运动,而且耦合了WOFOST作物模型使作物的生长描述更为科学。 本文让更多的科研人员和农业工作者

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP