• <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>
            Fork me on GitHub
            隨筆 - 215  文章 - 13  trackbacks - 0
            <2016年3月>
            282912345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789


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

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            相冊(cè)

            Awesome

            Blog

            Book

            GitHub

            Link

            搜索

            •  

            積分與排名

            • 積分 - 216756
            • 排名 - 118

            最新評(píng)論

            閱讀排行榜

            基于 OpenResty 的服務(wù)器架構(gòu)設(shè)計(jì)

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

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

            1. 技術(shù)選擇

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

            2. 邏輯服務(wù)器

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

            dtserver 為 data_tester 提供 WebSocket 服務(wù)。

            socketserver 為 client 提供 WebSocket 服務(wù),httpserver 為 client 提供 HTTP 服務(wù)。

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

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

            Counstruction for OpenResty

            3. 開發(fā)者分離

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

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

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

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

            對(duì)于 Redis,也進(jìn)行類似的操作,每個(gè)開發(fā)者綁定一個(gè)獨(dú)立的 Redis 配置文件和端口號(hào)。

            HTTP 和 MySql 服務(wù)是共享的,不需要單獨(dú)分配。因?yàn)樗虚_發(fā)者都共享相同的用戶信息。

            4. 部署工具

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

            4.1 serverctrl

            serverctrl 是一個(gè)專用于控制服務(wù)器的 git 倉(cāng)庫(kù)。

            下面的 OpenResty 服務(wù)器的和 redis 服務(wù)器的配置文件模版都保存在這個(gè) git 庫(kù)中。

            4.2 OpenResty 服務(wù)器

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

            4.2.1 支持的服務(wù)器

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

            服務(wù)器服務(wù)器路徑
            socketserver/opt/hhl/socketserver/[user]
            dtserver/opt/hhl/dtserver/[user]
            httpserver/opt/hhl/httpserver/[user]

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

            每個(gè) OpenResty 服務(wù)器程序?qū)嵗加型耆?dú)立的一套配置,以/opt/hhl/socketserver/dev1 為例,包含這樣幾個(gè)子文件夾:

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

            4.2.3 配置文件模版

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

            上面提到的 nginx.conf 配置文件的模版位于 serverctrl 的 git 倉(cāng)庫(kù)中。模版文件為: 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 是配置文件基準(zhǔn)值,下面的屬性會(huì)替換掉 master 中的同名值,然后寫入配置文件。

            4.3 Redis 服務(wù)器

            下面的例子是中,使用 [port] 代表 redis 服務(wù)器程序使用的端口號(hào)。

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

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

            每個(gè) Redis 服務(wù)器實(shí)例,使用不同的端口號(hào)和配置文件,完全獨(dú)立。

            上面提到的配置文件的模版位于 serverctrl 的 git 倉(cāng)庫(kù)中。模版文件為: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 鉤子,部署代碼與重啟服務(wù)

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

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

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

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

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

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

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

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

            詳情見這兩個(gè)實(shí)現(xiàn):

            (全文完)


            posted on 2016-08-01 09:42 思月行云 閱讀(693) 評(píng)論(0)  編輯 收藏 引用 所屬分類: Nginx\Openresty
            久久99国产精品久久99果冻传媒| 影音先锋女人AV鲁色资源网久久 | 久久久久综合网久久| 欧洲精品久久久av无码电影| 精品无码久久久久久尤物| 国产—久久香蕉国产线看观看 | 久久精品一区二区三区中文字幕| 午夜精品久久影院蜜桃| 久久香蕉超碰97国产精品| 久久精品亚洲欧美日韩久久| 日日噜噜夜夜狠狠久久丁香五月| 91久久香蕉国产熟女线看| 亚洲国产精品无码久久98| 久久免费大片| 久久久精品一区二区三区| 亚洲AV无码一区东京热久久| 久久91精品综合国产首页| 久久久久久九九99精品| 久久精品国产亚洲AV香蕉| 中文字幕亚洲综合久久| AV无码久久久久不卡蜜桃| 精品久久久无码21p发布 | 久久久久久亚洲精品成人| 国产成人综合久久精品红| 国内精品伊人久久久久网站| 99久久人妻无码精品系列| 久久亚洲精品国产精品| 伊人情人综合成人久久网小说| 日本精品久久久中文字幕| 国产精品久久久久久久久鸭 | 国产精品一区二区久久精品涩爱 | 国产99久久久久久免费看| 69久久精品无码一区二区| 亚洲综合伊人久久综合| 狠狠综合久久AV一区二区三区 | 亚洲AV无码久久精品狠狠爱浪潮| 一本综合久久国产二区| 中文字幕精品久久| 伊人久久精品影院| 99久久99久久精品国产片果冻 | 国产精品久久久久久五月尺|