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

相关文章

python依赖管理工具UV的安装和使用教程

《python依赖管理工具UV的安装和使用教程》UV是一个用Rust编写的Python包安装和依赖管理工具,比传统工具(如pip)有着更快、更高效的体验,:本文主要介绍python依赖管理工具UV... 目录前言一、命令安装uv二、手动编译安装2.1在archlinux安装uv的依赖工具2.2从github

JDK8(Java Development kit)的安装与配置全过程

《JDK8(JavaDevelopmentkit)的安装与配置全过程》文章简要介绍了Java的核心特点(如跨平台、JVM机制)及JDK/JRE的区别,重点讲解了如何通过配置环境变量(PATH和JA... 目录Java特点JDKJREJDK的下载,安装配置环境变量总结Java特点说起 Java,大家肯定都

linux部署NFS和autofs自动挂载实现过程

《linux部署NFS和autofs自动挂载实现过程》文章介绍了NFS(网络文件系统)和Autofs的原理与配置,NFS通过RPC实现跨系统文件共享,需配置/etc/exports和nfs.conf,... 目录(一)NFS1. 什么是NFS2.NFS守护进程3.RPC服务4. 原理5. 部署5.1安装NF

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

Nginx部署HTTP/3的实现步骤

《Nginx部署HTTP/3的实现步骤》本文介绍了在Nginx中部署HTTP/3的详细步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前提条件第一步:安装必要的依赖库第二步:获取并构建 BoringSSL第三步:获取 Nginx

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队

redis-sentinel基础概念及部署流程

《redis-sentinel基础概念及部署流程》RedisSentinel是Redis的高可用解决方案,通过监控主从节点、自动故障转移、通知机制及配置提供,实现集群故障恢复与服务持续可用,核心组件包... 目录一. 引言二. 核心功能三. 核心组件四. 故障转移流程五. 服务部署六. sentinel部署

linux系统上安装JDK8全过程

《linux系统上安装JDK8全过程》文章介绍安装JDK的必要性及Linux下JDK8的安装步骤,包括卸载旧版本、下载解压、配置环境变量等,强调开发需JDK,运行可选JRE,现JDK已集成JRE... 目录为什么要安装jdk?1.查看linux系统是否有自带的jdk:2.下载jdk压缩包2.解压3.配置环境

Python库 Django 的简介、安装、用法入门教程

《Python库Django的简介、安装、用法入门教程》Django是Python最流行的Web框架之一,它帮助开发者快速、高效地构建功能强大的Web应用程序,接下来我们将从简介、安装到用法详解,... 目录一、Django 简介 二、Django 的安装教程 1. 创建虚拟环境2. 安装Django三、创

linux安装、更新、卸载anaconda实践

《linux安装、更新、卸载anaconda实践》Anaconda是基于conda的科学计算环境,集成1400+包及依赖,安装需下载脚本、接受协议、设置路径、配置环境变量,更新与卸载通过conda命令... 目录随意找一个目录下载安装脚本检查许可证协议,ENTER就可以安装完毕之后激活anaconda安装更