青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Fork me on GitHub
隨筆 - 215  文章 - 13  trackbacks - 0
<2018年10月>
30123456
78910111213
14151617181920
21222324252627
28293031123
45678910


專注即時通訊及網(wǎng)游服務端編程
------------------------------------
Openresty 官方模塊
Openresty 標準模塊(Opm)
Openresty 三方模塊
------------------------------------
本博收藏大部分文章為轉(zhuǎn)載,并在文章開頭給出了原文出處,如有再轉(zhuǎn),敬請保留相關(guān)信息,這是大家對原創(chuàng)作者勞動成果的自覺尊重!!如為您帶來不便,請于本博下留言,謝謝配合。

常用鏈接

留言簿(1)

隨筆分類

隨筆檔案

相冊

Awesome

Blog

Book

GitHub

Link

搜索

  •  

積分與排名

  • 積分 - 220944
  • 排名 - 117

最新評論

閱讀排行榜

基于 OpenResty 的服務器架構(gòu)設計

  • 本文版權(quán)歸 zengrong 所有,此處為技術(shù)收藏,如有再轉(zhuǎn),敬請標明原文作者及出處,這是對原作者勞動成果的自覺尊重!!
  • 本文鏈接:http://zengrong.net/post/2228.htm

這個服務器架構(gòu)不一定能用上,記錄在這里,算是一個小小的學習成果。

1. 技術(shù)選擇

  • Cocos2d-x 3.x —— 客戶端框架。
  • WebSockt —— 網(wǎng)絡協(xié)議。
  • HTTP —— 網(wǎng)絡協(xié)議。
  • OpenResty —— 基于 nginx+lua 實現(xiàn) WebSocket 或 HTTP 服務器。
  • MySQL —— 數(shù)據(jù)庫支持。
  • Redis —— NoSQL 支持。

2. 邏輯服務器

有兩個不同的客戶端需要提供服務。data_tester 和 client 。它們都需要 WebSocket 服務, client 還需要 HTTP 服務。

dtserver 為 data_tester 提供 WebSocket 服務。

socketserver 為 client 提供 WebSocket 服務,httpserver 為 client 提供 HTTP 服務。

dtserver/socketserver/httpserver 均使用 OpenResty(with lua) 實現(xiàn)。

下圖表述了這種關(guān)系。虛線框內(nèi)代表邏輯服務器部署。

Counstruction for OpenResty

3. 開發(fā)者分離

共有 4 個開發(fā)者 dev1~dev4 ,他們需要獨立的服務器環(huán)境進行開發(fā)與測試。

按照常規(guī),開發(fā)者可以在自己的開發(fā)計算機上建立服務器環(huán)境進行開發(fā),待測試完畢后,合并代碼并部署到公用服務器上進行測試。

但 OpenResty 在 Windows 系統(tǒng)上編譯比較麻煩,于是我采取了上圖所示的部署方式:

在服務器上為每個開發(fā)者綁定一個獨立的 OpenResty 端口和 master 進程,使用獨立的端口號、配置文件和服務端代碼(lua files),這樣能夠?qū)崿F(xiàn)完全隔離。

對于 Redis,也進行類似的操作,每個開發(fā)者綁定一個獨立的 Redis 配置文件和端口號。

HTTP 和 MySql 服務是共享的,不需要單獨分配。因為所有開發(fā)者都共享相同的用戶信息。

4. 部署工具

由于所有的代碼都在遠程服務器上,為了方便開發(fā)者管理服務器、更新自己的測試代碼,我使用 git 庫鉤子和腳本來實現(xiàn)了一套部署工具。

4.1 serverctrl

serverctrl 是一個專用于控制服務器的 git 倉庫。

下面的 OpenResty 服務器的和 redis 服務器的配置文件模版都保存在這個 git 庫中。

4.2 OpenResty 服務器

下面的例子是中,使用 [server] 代表服務器名稱,使用 [user] 代表開發(fā)者名稱(也是 git 庫的分支名稱)。

4.2.1 支持的服務器

OpenResty 服務器程序部署在 /opt/hhl 文件夾中,下面幾個服務器都是基于 OpenResty 的:

服務器服務器路徑
socketserver/opt/hhl/socketserver/[user]
dtserver/opt/hhl/dtserver/[user]
httpserver/opt/hhl/httpserver/[user]

4.2.2 每個服務器程序的文件夾結(jié)構(gòu)

每個 OpenResty 服務器程序?qū)嵗加型耆毩⒌囊惶着渲茫?/span>/opt/hhl/socketserver/dev1 為例,包含這樣幾個子文件夾:

  • logs 存放 log 日志和 pid 文件;
  • conf 其中只有一個 nginx.conf 配置文件,供當前的 OpenResty 服務器程序?qū)嵗褂茫?/span>
  • src 服務器邏輯的 lua 文件。

4.2.3 配置文件模版

每個 OpenResty 服務器程序?qū)嵗际褂貌煌亩丝凇?prefix 和配置文件,完全獨立。

上面提到的 nginx.conf 配置文件的模版位于 serverctrl 的 git 倉庫中。模版文件為: nginx.[server].templ.conf ,用于替換模版的值文件為nginx.[server].sub.py 。

下面是 nginx.socketserver.templ.conf 的內(nèi)容:

worker_processes  $WORKER_PROCESSES;  error_log  logs/error.log  debug;  events {     worker_connections  1024; }  http {     lua_package_path "/opt/hhl/socketserver/$USER_NAME/src/?.lua;;";     lua_code_cache $LUA_CODE_CACHE;      server {         listen       $LISTEN;         server_name  $SERVER_NAME;          location /hhl {             content_by_lua_file  src/main.lua;         }     }  } 

下面是 nginx.socketserver.sub.py 的內(nèi)容:

{     'master':{         'WORKER_PROCESSES' : 1,         'LUA_CODE_CACHE':'off',         'LISTEN':'1080',         'SERVER_NAME':'localhost',     },     'dev1':{         'LISTEN':'1081',     },     'dev2':{         'LISTEN':'1082',     },     'dev3':{         'LISTEN':'1083',     },     'dev4':{         'LISTEN':'1084',     }, } 

從上面的配置可以看出,master 是配置文件基準值,下面的屬性會替換掉 master 中的同名值,然后寫入配置文件。

4.3 Redis 服務器

下面的例子是中,使用 [port] 代表 redis 服務器程序使用的端口號。

redis 服務器程序部署在 /opt/redis 文件夾中,與 OpenResty 不同,Redis 沒有采用分文件夾的方式,而是采用不同的配置文件來實現(xiàn)隔離。

配置文件名為: /opt/redis/etc/[port].conf 。

每個 Redis 服務器實例,使用不同的端口號和配置文件,完全獨立。

上面提到的配置文件的模版位于 serverctrl 的 git 倉庫中。模版文件為:redis.templ.conf ,用于替換模版的值文件為 redis.sub.py 。

下面是 redis.templ.py 的內(nèi)容:

include /opt/redis/etc/redis.conf  daemonize yes pidfile /opt/redis/var/$PORT.pid port $PORT bind $BIND tcp-keepalive 0 loglevel notice logfile $PORT.log databases 16 dbfilename $PORT.rdb dir /opt/redis/var/ appendonly no appendfilename "$PORT.aof" syslog-enabled yes syslog-ident redis-$PORT syslog-facility local5 

下面是 redis.sub.py 的內(nèi)容:

{     'master':{         'PORT': 6379,         'BIND': '127.0.0.1 192.168.18.18',     },     'dev1':{         'PORT': 6381,     },     'dev2':{         'PORT': 6382,     },     'dev3':{         'PORT': 6383,     },     'dev4':{         'PORT': 6384,     }, } 

替換規(guī)則與 OpenResty 的相同。

5. git 鉤子,部署代碼與重啟服務

要將本地的代碼部署到服務器上,只需要通過 git 鉤子,在提交本地代碼的同時,更新服務器上的代碼即可。

同時,不是所有的開發(fā)者都有服務器的管理權(quán)限。我使用 git 鉤子提供了重啟服務的功能,讓所有開發(fā)者都可以實現(xiàn)對自己的 Redis、OpenResty 進程的控制。

我在這篇文章中作了描述:使用 git post-receive 鉤子部署服務端代碼 。

另外,由于存在 3 個服務器程序,涉及到許多通用代碼和庫。我將這些代碼放置在一個單獨的 git 項目中,不對所有的開發(fā)者可見,但提供開發(fā)者文檔。這樣一來,開發(fā)者在自己的服務器程序中,只需要關(guān)注邏輯相關(guān)的代碼,而不必在意底層庫是如何實現(xiàn)的。

6. log 日志系統(tǒng)

由于開發(fā)者沒有服務器權(quán)限,無法看到服務的出錯日志。為了解決這個問題,我將所有的錯誤日志使用 rsyslog 來管理,同時提供了基于 web 的查看系統(tǒng)。這樣一來,開發(fā)者們完全不必和服務器打交道了。

我在這篇文章中作了描述:rsyslog/Python/LogAnalyzer 記錄和查看日志 。

我基于 OpenResty 提供的 resty.logger.socket 實現(xiàn)了從服務端的 lua 代碼中將 log 提交到 rsyslog,這樣開發(fā)者調(diào)試代碼也可以使用這種方式。

詳情見這兩個實現(xiàn):

(全文完)


posted on 2016-08-01 09:42 思月行云 閱讀(711) 評論(0)  編輯 收藏 引用 所屬分類: Nginx\Openresty
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲一区免费观看| 国产美女诱惑一区二区| 国产欧美日韩| 免费观看欧美在线视频的网站| 久久综合九色综合网站| 亚洲最新视频在线| 亚洲一区二区三区777| 狠狠色丁香久久综合频道| 91久久线看在观草草青青| 欧美日韩1234| 久久精品中文字幕免费mv| 欧美 日韩 国产一区二区在线视频| 亚洲天堂成人在线观看| 久久精品在线| 亚洲自拍高清| 麻豆久久婷婷| 性色一区二区| 欧美精品一区二区视频| 久久人人爽爽爽人久久久| 欧美日韩国产亚洲一区| 美腿丝袜亚洲色图| 欧美亚州一区二区三区| 亚洲精品欧美| 99热这里只有精品8| 激情综合网址| 亚洲综合色婷婷| 99精品欧美| 久久久91精品国产一区二区精品| 亚洲欧美韩国| 欧美国产精品人人做人人爱| 久久久久久亚洲精品杨幂换脸 | 国产亚洲欧美一区二区三区| 亚洲精选91| 亚洲国产视频直播| 午夜宅男欧美| 激情成人亚洲| 国产精品永久在线| 欧美fxxxxxx另类| 国产欧美日韩三区| 99成人精品| 99国产精品自拍| 麻豆精品网站| 麻豆精品在线播放| 黄色日韩网站| 欧美亚洲午夜视频在线观看| 亚洲免费中文字幕| 欧美国产第一页| 亚洲第一精品在线| 在线观看欧美黄色| 欧美在线观看视频一区二区三区| 亚洲综合日韩在线| 欧美日韩国产999| 亚洲另类在线视频| 一本一本久久a久久精品综合妖精| 美国十次成人| 亚洲第一二三四五区| 最新日韩精品| 欧美电影在线观看完整版| 亚洲国产cao| 亚洲美女色禁图| 欧美国产在线观看| 亚洲精品国产精品乱码不99按摩| 亚洲人线精品午夜| 欧美日韩高清在线观看| 夜色激情一区二区| 亚洲一区二区三区成人在线视频精品| 欧美区日韩区| 这里只有精品视频| 欧美在线1区| 国产欧美精品一区二区三区介绍| 午夜精品三级视频福利| 久久亚洲一区二区三区四区| 国产一区二区精品久久99| 午夜在线观看免费一区| 美女久久一区| 日韩午夜在线观看视频| 欧美图区在线视频| 久久9热精品视频| 欧美激情小视频| 亚洲天堂av高清| 国产亚洲亚洲| 蜜臀av性久久久久蜜臀aⅴ| 亚洲精品在线免费| 欧美一区二区三区免费观看视频| 欧美一区二区三区免费在线看| 在线观看福利一区| 欧美激情在线观看| 亚洲一区激情| 久久久人人人| 99国产精品自拍| 国产精品xxxxx| 久久久99精品免费观看不卡| 亚洲黄色有码视频| 欧美一进一出视频| 亚洲黄色av一区| 国产精品久久久久久久午夜片| 久久精品国产精品亚洲| 夜夜嗨av一区二区三区| 免费在线成人| 午夜精品影院| 亚洲人成绝费网站色www| 国产日韩在线播放| 欧美另类久久久品| 久久高清国产| 一区二区三区福利| 欧美91精品| 久久成人资源| 一区二区三区精品国产| 136国产福利精品导航| 欧美日韩中文字幕| 老色批av在线精品| 欧美一区三区三区高中清蜜桃| 亚洲欧洲一区二区在线播放| 久久久久久久国产| 亚洲欧美成人在线| 日韩午夜av在线| 好吊色欧美一区二区三区视频| 欧美网站在线| 欧美老女人xx| 裸体歌舞表演一区二区| 亚洲在线免费| 一区二区三区久久久| 亚洲人成毛片在线播放女女| 欧美a一区二区| 麻豆亚洲精品| 久久精品99国产精品| 亚洲午夜精品在线| 亚洲卡通欧美制服中文| 国内精品久久久久影院色| 国产精品日韩电影| 欧美日韩一区二区欧美激情| 欧美成人一区二区三区| 久久亚洲精品一区| 久久久精品一区| 久久精品一区二区国产| 久久久av水蜜桃| 亚洲电影专区| 亚洲电影激情视频网站| 激情久久久久| 1000部国产精品成人观看| 伊人成人在线视频| 激情久久久久| 亚洲高清不卡在线观看| 在线精品亚洲| 国内一区二区三区在线视频| 黄色一区二区三区| 亚洲电影免费在线观看| 亚洲国产另类精品专区| 亚洲精品美女久久7777777| 亚洲人成网站精品片在线观看| 亚洲精品在线电影| 亚洲一区亚洲| 久久国产欧美精品| 99在线精品视频| 日韩视频第一页| 一本不卡影院| 在线视频一区二区| 亚洲一区黄色| 欧美极品一区| 久久免费视频网站| 美女主播视频一区| 欧美高清在线一区| 欧美视频在线不卡| 国产亚洲精久久久久久| 韩国av一区| 亚洲精品三级| 亚洲婷婷在线| 久久成人综合网| 欧美成人有码| 一本色道久久综合亚洲精品不卡| 一区二区三区日韩欧美精品| 欧美在线一区二区| 欧美成人精品在线观看| 欧美日韩国产区| 国产亚洲美州欧州综合国| 亚洲激情在线| 午夜精彩视频在线观看不卡| 狂野欧美性猛交xxxx巴西| 亚洲高清视频在线| 亚洲一级黄色av| 久久亚洲不卡| 国产精品久久久久免费a∨大胸| 国产亚洲欧美激情| 日韩视频久久| 久久蜜桃精品| 一本色道久久精品| 久久精品亚洲乱码伦伦中文| 欧美人交a欧美精品| 国产又爽又黄的激情精品视频| 亚洲欧洲日产国产综合网| 亚洲欧美一区二区原创| 亚洲美女视频在线观看| 亚洲欧美综合v| 久久久精品tv| 最新高清无码专区| 欧美中文字幕在线| 欧美日韩精品免费看 | 国产视频一区在线| 日韩午夜激情| 鲁大师成人一区二区三区|