• <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>

            concentrate on c/c++ related technology

            plan,refactor,daily-build, self-discipline,

              C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
              37 Posts :: 1 Stories :: 12 Comments :: 0 Trackbacks

            常用鏈接

            留言簿(9)

            我參與的團隊

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            現在nginx的版本已經到了1.9.12,不過在1.9.0的時候,就開始了對TCP代理服務器的支持。
            之前也有一些早期的做法,比如就有寫了nginx_tcp_module模塊的https://github.com/yaoweibin/nginx_tcp_proxy_module,
            以及nginx_stream_lua模塊的
            https://github.com/openresty/stream-lua-nginx-module
            本來就想著用這兩個的,后來發現已經有支持了,就先來試試看看這個了。
            默認的話,nginx是沒有開啟對tcp的支持的.如果要支持的話,需要用--with-stream去指定。
            我這邊只要需要三個IP,一個是nginx進程所在的機器,我這邊用192.168.1.4表示,
            另外兩臺就是TCP上游業務服務器,我們分別用192.168.1.5和192.168.1.21來表示,
            基于這樣的考慮是因為nginx充當tcp代理服務器后,自身也會占用一個端口。
            并且從目前來說,貌似一個nginx進程也就只能listen一個端口。
            我用的版本是nginx 1.9.9.
            我在/usr/local/nginx/conf下面新建了nginx_stream_tcp.conf作為本次的測試。
            worker_processes auto;
              2 error_log /usr/local/nginx/logs/error.log info;
              3 events {
              4     worker_connections  1024;
              5 }
              6
              7 stream {
              8     upstream loadbalance {
              9 # Specifies a load balancing method for a server group where client-server mapping is based on the hashed key value
             10         hash $remote_addr consistent;
             11 # sets the weight of the server, by default, 1.
             12         server 192.168.1.21:8001 weight=5;
             13 # by default, the parameter is set to 10 seconds.
             14         server 192.168.1.5:9001  max_fails=3 fail_timeout=30s;
             15
             16 
             17     }
             18
             19 server {
             20 # listen 8001.
             21         listen 8001;
             22 # Defines a timeout for establishing a connection with a proxied server.
             23         proxy_connect_timeout 1s;
             24 # Sets the timeout between two successive read or write operations on client or proxied server connections
             25         proxy_timeout 3s;
             26 # Sets the address of a proxied server
             27         proxy_pass loadbalance;
             28     }
             29
             30 }
            這個大部分是官網支持的,所以其實我也沒有修改太多,就設置了幾個IP和端口。
            在編譯好nginx后,可以用/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx_stream_tcp.conf
            就可以起來了,可以通過netstat -tlnp查看是否起來,大致顯示這樣的:
            tcp        0      0 0.0.0.0:8001            0.0.0.0:*               LISTEN      7744/nginx_stream_t
            當然也可以通過telnet來查看。
            接下來,寫個簡單的cs程序來驗證下吧.

            server端:
            if __name__ == '__main__':
             import socket
             import commands
             sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
             sock.bind(('192.168.1.21', 8001))
             sock.listen(5)
             while True:
              connection,address = sock.accept()
              print "connected by",address
              while 1:

                buf = connection.recv(1024)
                if buf != "" :
                 print "connection buffer", buf
                 connection.sendall(buf)
             connection.close()

            client端:
            if __name__ == '__main__': 
                import socket
                HOST='192.168.1.4'
                PORT=8001
                sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) 
                sock.connect((HOST, PORT))
                while 1:
                    cmd = raw_input("please input cmd:")
                    sock.sendall(cmd)
                    data = sock.recv(1024)
                    print data
                sock.close()

            在client向192.168.1.4發起一個TCP連接時,接下來192.168.1.4會連接到192.168.1.21,
            192.168.1.21的server端會顯示, connected by ('192.168.1.4',58559)
            后面的端口應該是隨機的臨時端口。
            其實它的確起到了轉發作用,這個nginx進程相當于一個通用網關,如果有兩個client向nginx進程發起連接,一旦nginx那邊調度到同一個上游TCP服務器,那么只需要從NGINX進程建立一個TCP連接到上游TCP服務器即可。
            之前我自己設計網關的時候,不是依賴于用戶的,而是通過靜態配置來建立連接的,比如上游邏輯服務器跟網關有連接,那都是在啟動服務器的時候,就建立起來了。
            這樣有個好處就是可以省事,不過也可以采用這種方式,有玩家連接進某個上游TCP服務器才讓網關跟這個TCP服務器建立連接,否則無需處理。因為不少時候還是會有不少服務器處于空閑的.

            posted on 2016-03-11 08:44 jolley 閱讀(859) 評論(0)  編輯 收藏 引用 所屬分類: nginx
            亚洲色欲久久久综合网| 久久久久99精品成人片试看| 欧美精品一区二区久久| 久久笫一福利免费导航| 2022年国产精品久久久久| 久久99久久成人免费播放| 国产成人精品综合久久久| 国产女人aaa级久久久级| 亚洲狠狠婷婷综合久久蜜芽 | 久久99九九国产免费看小说| 欧美一区二区三区久久综合| 欧美麻豆久久久久久中文| 久久国产乱子伦免费精品| 亚洲国产精品无码久久青草| 成人免费网站久久久| 久久久久久精品无码人妻| 大美女久久久久久j久久| 久久久国产乱子伦精品作者| 国产香蕉久久精品综合网| 热99re久久国超精品首页| 久久久久成人精品无码中文字幕| 亚洲精品97久久中文字幕无码| 国产精品久久久久9999| 色偷偷久久一区二区三区| 久久久久久精品成人免费图片| 久久人搡人人玩人妻精品首页| 国产精品久久久久久影院| 99精品久久精品| 蜜臀av性久久久久蜜臀aⅴ| 久久精品国产99久久久古代| 亚洲伊人久久成综合人影院| 亚洲国产精品成人久久蜜臀 | 久久免费大片| 久久人人爽人爽人人爽av| 日韩va亚洲va欧美va久久| 久久强奷乱码老熟女网站| 久久久精品国产Sm最大网站| 国产福利电影一区二区三区,免费久久久久久久精 | 欧美伊香蕉久久综合类网站| 久久久精品免费国产四虎| 国产精品久久亚洲不卡动漫|