此配置适合o2集群部署或者外网访问o2server服务(如移动端h5方式访问o2)
此配置需要o2server V5.2及以上版本
主机信息
主机1:172.16.98.8(linux)
主机2:172.16.98.9(linux)
集群需求
172.16.98.8:WEB服务器,应用服务器,文件存储服务器,中心服务器
172.16.98.9:WEB服务器,应用服务器,文件存储服务器,中心服务器
数据库
mysql数据库
nginx访问域名及端口
域名:qmx.o2oa.net(可以用ip,如果域名没有解析需要配置hosts)
端口:80(o2web服务器、o2应用服务器、o2中心服务器)
分发规则(下面的上下文(如:/dev/web)不是固定的,可以根据自身需要需改):
nginx80端口匹配的上下文 |
o2端口服务 |
/dev/web/ | 8080(o2web服务器) |
/dev/app/ | 20020(o2应用服务器) |
/dev/center/ |
20030(o2中心服务器) |
配置步骤
一、配置节点标识
1、在主机172.16.98.8的o2server/local目录中修改或者新增文件node.cfg,修改内容为主机的域名或者IP;
主机172.16.98.8的节点标识文件配置
172.16.98.8 |
2、在主机172.16.98.9的o2server/local目录中修改或者新增文件node.cfg,修改内容为主机的域名或者IP;
主机172.16.98.9的节点标识文件配置
172.16.98.9 |
二、配置node文件
1、从172.16.98.8主机的o2server/configSample目录中copy文件node_127.0.0.1.json到o2server/config目录,命名为node_172.16.98.8.json,再拷贝一份命名为node_172.16.98.9.json;
2、修改node_172.16.98.8.json文件如下(红色部分需关注):
{ "enable": true, "isPrimaryCenter": true, "center": { "enable": true, "order": 1.0, "sslEnable": false, "redeploy": true, "port": 20030.0, "httpProtocol": "", "proxyHost": "qmx.o2oa.net", "proxyPort": 20030.0, "scanInterval": 0.0, "configApiEnable": true, "statEnable": true, "statExclusions": "*.js,*.gif,*.jpg,*.png,*.css,*.ico", "maxFormContent": 20.0 }, "application": { "enable": true, "port": 20020.0, "sslEnable": false, "proxyHost": "qmx.o2oa.net", "proxyPort": 20020, "redeploy": true, "scanInterval": 0.0, "includes": [], "excludes": [], "weights": [], "scheduleWeights": [], "statEnable": true, "statExclusions": "*.js,*.gif,*.jpg,*.png,*.css,*.ico", "maxFormContent": 20.0 }, "web": { "enable": true, "port": 8080.0, "sslEnable": false, "proxyHost": "", "weight": 100.0, "dirAllowed": false, "statEnable": false, "statExclusions": "*.gif,*.jpg,*.png,*.ico", "cacheControlMaxAge": 0.0 }, "data": { "enable": false, "tcpPort": 20050.0, "webPort": 20051.0, "includes": [], "excludes": [], "jmxEnable": false, "cacheSize": 512.0, "logLevel": "WARN", "maxTotal": 50.0, "maxIdle": 0.0, "statEnable": true, "statFilter": "mergeStat", "slowSqlMillis": 2000.0 }, "storage": { "enable": true, "port": 20040.0, "sslEnable": false, "name": "251", "accounts": [], "prefix": "", "deepPath": false }, ... } |
3、修改node_172.16.98.9.json文件如下(红色部分需关注):
{ "enable": true, "isPrimaryCenter": true, "center": { "enable": true, "order": 2.0, "sslEnable": false, "redeploy": true, "port": 20030.0, "httpProtocol": "", "proxyHost": "qmx.o2oa.net", "proxyPort": 20030.0, "scanInterval": 0.0, "configApiEnable": true, "statEnable": true, "statExclusions": "*.js,*.gif,*.jpg,*.png,*.css,*.ico", "maxFormContent": 20.0 }, "application": { "enable": true, "port": 20020.0, "sslEnable": false, "proxyHost": "qmx.o2oa.net", "proxyPort": 20020.0, "redeploy": true, "scanInterval": 0.0, "includes": [], "excludes": [], "weights": [], "scheduleWeights": [], "statEnable": true, "statExclusions": "*.js,*.gif,*.jpg,*.png,*.css,*.ico", "maxFormContent": 20.0 }, "web": { "enable": true, "port": 8080.0, "sslEnable": false, "proxyHost": "", "weight": 100.0, "dirAllowed": false, "statEnable": false, "statExclusions": "*.gif,*.jpg,*.png,*.ico", "cacheControlMaxAge": 0.0 }, "data": { "enable": false, "tcpPort": 20050.0, "webPort": 20051.0, "includes": [], "excludes": [], "jmxEnable": false, "cacheSize": 512.0, "logLevel": "WARN", "maxTotal": 50.0, "maxIdle": 0.0, "statEnable": true, "statFilter": "mergeStat", "slowSqlMillis": 2000.0 }, "storage": { "enable": true, "port": 20040.0, "sslEnable": false, "name": "252", "accounts": [], "prefix": "", "deepPath": false }, ... } |
4、从172.16.98.8主机的o2server/configSample目录中copy文件externalDataSources_mysql.json到o2server/config目录,命名为externalDataSources.json,然后修改配置文件中数据库相应的配置信息;
5、从172.16.98.8上复制修改好的node_172.16.98.8.json、node_172.16.98.9.json和externalDataSources.json文件到172.16.98.9的o2server/config目录。
三、配置路径映射
1、分别从172.16.98.8和172.16.98.9主机的o2server/configSample目录中copy文件portal.json到o2server/config目录。
2、修改portal.json(修改urlMapping的内容,其他保持不变)
{ "indexPage": { "enable": false, "portal": "", "page": "" }, "loginPage": { "enable": false, "portal": "", "page": "" }, "urlMapping": { "qmx.o2oa.net:20020": "qmx.o2oa.net/dev/app", "qmx.o2oa.net:20030": "qmx.o2oa.net/dev/center" }, "###indexPage": "定制首页面设置.###", "###loginPage": "定制登录页面设置.###" }
四、启动服务器
1、进入o2server目录,执行./start_linux.sh,当显示出o2命令信息时输入start启动服务,观察center服务、app服务器、web服务启动是否正常;
2、当两台服务器都启动正常后进入nginx服务器,telnet这两台服务器3个服务的端口,确保nginx到o2服务器网络正常;
五、配置nginx
nginx代理转发逻辑:
进入nginx的nginx.conf文件,修改配置(参考如下),然后重启nginx。
http { include mime.types; default_type application/octet-stream; charset utf-8;
#access_log logs/access.log main; client_max_body_size 100m; # 数据包大小限制 sendfile on; tcp_nopush on;
keepalive_timeout 65;
#gzip on;
upstream webServer { # Server: 分发名 server 172.16.98.8:8080; # 分发地址1 server 172.16.98.9:8080; # 分发地址2 } upstream appServer { server 172.16.98.8:20020; server 172.16.98.9:20020; } upstream centerServer { server 172.16.98.8:20030; server 172.16.98.9:20030; }
server { listen 80; server_name localhost; proxy_http_version 1.1; proxy_read_timeout 300s; proxy_set_header Upgrade $http_upgrade; # 支持websocket连接 proxy_set_header Connection "upgrade"; # 支持websocket连接 proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header REMOTE-HOST $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; location /dev/web/ { root html; index index.html; proxy_pass http://webServer/; } location /dev/app/ { proxy_pass http://appServer/; } location /dev/center/ { proxy_pass http://centerServer/; } } } |
|
六、测试验证
1、浏览器访问地址:http://qmx.o2oa.net/dev/web 使用 xadmin/o2登录;
2、进入98.8主机的o2server目录,键入./stop_linux.sh ,刷新页面正常访问;
3、进入98.9主机的o2server目录,键入./stop_linux.sh ,刷新页面出现502 Bad Gateway;
4、进入98.8主机的o2server目录,键入./start_linux.sh进入命令行后键入start ,刷新页面正常访问;
相关推荐
nginx-rtmp-module 软件准备 1.安装 Visual Studio 2019 包含单个组件: .NET Framework 4.6.1 目标包 .NET Framework 4.6.1 SDK Windows 通用 C 运行时 Windows 通用 CRT SDK MSVC v142 - VS 2019 C++ x64/x86 生成...
--> nginx-1.21.6 ======================== 在网上查找半天都只有教程,没有可免费下载的版本,深知没有积分遍地找资源的痛苦,无奈之下只好自己按照教程一步一个坑编译出来的,供大家免费下载使用。(无毒放心使用...
nginx sticky是nginx的module,可以实现基于cookie的负载均衡。 下载后,在编译安装nginx时,用--add-module选项,指到sticky所在目录。类似命令如下: ./configure --prefix=/usr/local/nginx-1.6.0 --add-module=...
windows平台nginx编译nginx-http-flv-module,可直接运行,基于nginx-1.17.10编译
在windows 7 64位 环境下使用nginx的nginx-http-flv-module搭建flv视频流播放所有的安装包,参考:https://blog.csdn.net/qq_33071429/article/details/102628008
18进阶 5:基于 Nginx 的 API 部署方案(2)
基于 nginx 的 s3 代理 - docker 从 S3 为您的静态主页提供服务,同时通过在 docker 中运行的 nginx 代理来保持存储桶的私密性。 用法 克隆这个 repo: git clone --recursive ...
2023年5月26日,当前最新稳定版本nginx 1.24.0 已开启ipv6支持 二进制rpm包 适用于centos7 redhat 7系列的操作系统使用 适用于x86架构 主要修复安全漏洞、升级更新nginx版本,增强web服务器安全性
资源说明: 1. 采用nginx最新版编译,包含最新的nginx-http-flv-module,以及基础...1. 将压缩包解压到D:\nginx-1.19.3目录下 2. 使用cmd命令打开DOS,并切换到D:\nginx-1.19.3 3. 使用nginxservice.exe install安装
Sticky是nginx的一个模块,它是基于cookie的一种nginx的负载均衡解决方案,通过分发和识别cookie,来使同一个客户端的请求落在同一台服务器上,默认标识名为route (a)客户端首次发起访问请求,nginx接收后,发现...
"(五)prometheus 监控 nginx 服务"所需软件包其中之一:nginx-module-vts.tar.gz,大胆放心使用,不需要积分,只求浏览博客时留下您的评论和点赞,谢谢!
1、最新版 nginx-http-flv-module(windows可执行程序,含nginx 1.19.3,http-flv-module:1.2.7) 2、内含说明文档,请下载查看。 3、请勿放置于中文路径下,否则无法启动
nginx-http-flv-模块 基于流媒体服务器。。 如果您喜欢此模块,请捐赠。 非常感谢您!欣赏的创建者Igor Sysoev。 创建了Roman Arutyunyan。 贡献者,请参阅以获取详细信息。特征提供的所有功能。 nginx-...
1、在Windows系统下,搭建ffmpeg推流+nginx-http-flv-module直播拉流+FLV.js播放环境,所需依赖相关资源文件。 2、适合初学、研究、验证视频直播部署方案的相关技术人员。
windows服务注册: 1. 将压缩包解压到D:\nginx-1.19.3目录下 2. 使用cmd命令打开DOS,并切换到D:\nginx-1.19.3 3. 使用nginxservice.exe install安装 若需要自定义路径,注意在nginxservice.xml文件中修改路径
1、最新版 nginx-http-flv-module(windows_x64程序)-(程序版本:nginx1.23.2 & http-flv-module1.2.10) 2、内含说明文档,请下载查看。 3、请勿放置于中文路径下,否则无法启动
FastDFS分布式文件服务器搭建所需资源包:libfastcommon-master+fastdfs-nginx-module-master+fastdfs-master+nginx,搭建教程请见https://blog.csdn.net/Jeman_Yao/article/details/109102893
ingress-nginx-controller-v1.2.0_daemonset用到的镜像,免费下载
nginx-1.18.0-2.el7.ngx.x86_64.rpm安装包(含有部署手册) nginx-1.18.0-2.el7.ngx.x86_64.rpm安装包(含有部署手册) nginx-1.18.0-2.el7.ngx.x86_64.rpm安装包(含有部署手册) nginx-1.18.0-2.el7.ngx.x86_64.rpm...
nginx-vod模块 。 特征 快速将MP4文件重新打包为DASH,HDS,HLS,MSS 工作模式: 本地-提供本地可访问文件(已安装本地磁盘/ NFS) 远程-使用范围请求通过HTTP访问可访问的文件 映射-根据以JSON格式编码的规范...