nginx+tomcat單個域名及多個域名配置

夏雪冬日發表於2017-12-01

同步首發:http://www.yuanrengu.com/index.php/20171130.html

專案開發接近尾聲,開始著手在生產環境部署專案,開發階段部署專案都沒用nginx。專案是採用SOA架構,多系統開發,主要包括服務系統、中臺系統、後臺系統、金融系統、介面系統、排程系統、報表系統等。這類分散式的系統,一般也都會用到nginx來做負載均衡。

從公司剛成立就進來,趕鴨子上架來做架構師,負責公司的所有研發事情,搭建公司的整個技術架構,起初的所有核心業務程式碼基本都由自己親自把關來進行編碼。系統也從最初的只有一個pc端,發展到如今pc中臺、後臺、android端3個app、iOS端3個app,產品越做越多,親自負責招聘面試、培訓。之前很多時候都有過無助和苦惱,因為負責公司整個架構,又要負責核心業務的編碼,技術難點的攻克,新員工的招聘及培訓,現在團隊已經都發展到16個人,而且這全是研發人員。

回想這一路,覺得之前看似爬不過去的山也不過如此,也許這就是成長吧,成長總是會伴隨些許汗水與淚水吧。由於是負責團隊的所有事情,所以資料庫的維護、遷移資料、建索引等效能優化,專案部署等所有事情必須得一肩挑,不要問我為什麼公司沒有DBA?為什麼沒有運維?我真的只能給你一個眼神,讓你慢慢去體會。

話不多說,直接開始技術乾貨分享。

nginx做負載均衡的優勢網上有很多介紹資料,這裡我不再多做介紹。因為有很多系統要部署,涉及到域名、二級域名、多個域名等的部署。在實際的部署由於對nginx的不夠熟悉,遇到過很多坑,其中這種多域名的配置,xxxx.com轉發到www.xxxx.com、訪問域名轉發到tomcat裡的專案等,現在先總結一部坑的解決辦法。

如將xxxx.com這個域名指向8082埠裡的tomcat專案,在做這個介紹前先講個插曲,如訪問xxxx.com需轉向到www.xxxx.com,這一點很多人都會忽略。

現在如果要部署中臺、後臺、金融系統,找到nginx/conf/nginx.conf,修改配置:

 

    upstream web{
        server localhost:8082;
    }
	
	upstream admin{
        server localhost:8083;
    }
	
	upstream finance{
        server localhost:8084;
    }


	server {
        listen       80;
        server_name  finance.xxxx.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
			proxy_pass http://finance;
			proxy_set_header Host $http_host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        }

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }
	
	
    server {
        listen       80;
        server_name  www.xxx.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
			proxy_pass http://web;
			proxy_set_header Host $http_host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;			
        }

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ \.php$ {
        #    proxy_pass   http://127.0.0.1;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ \.php$ {
        #    root           html;
        #    fastcgi_pass   127.0.0.1:9000;
        #    fastcgi_index  index.php;
        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
        #    include        fastcgi_params;
        #}

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #    deny  all;
        #}
    }
	             
    server {
        server_name xxxx.com;
        rewrite ^(.*) http://www.xxxx.com$1 permanent;
    }
	
	
    server {
        listen       80;
        server_name  admin.xxxx.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
			proxy_pass  http://admin;
			proxy_set_header Host $http_host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;			
        }

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ \.php$ {
        #    proxy_pass   http://127.0.0.1;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ \.php$ {
        #    root           html;
        #    fastcgi_pass   127.0.0.1:9000;
        #    fastcgi_index  index.php;
        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
        #    include        fastcgi_params;
        #}

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #    deny  all;
        #}
    }

 上面的配置還包括了訪問xxxx.com轉向www.xxxx.com的配置,如下:

   server {
        server_name xxxx.com;
        rewrite ^(.*) http://www.xxxx.com$1 permanent;
    }

nginx的基本配置大致就是這樣,如果繫結多個域名(不管是一級域名還是二級域名),需配置多個server,你會發現這幾個server配置都差不多,主要是更改server_name及proxy_pass指向即可。upstream節點其實就是代理服務的訪問路徑。

如果此時訪問域名,你會發現nginx的配置生效了,只是目前顯示的是tomcat的預設介面。nginx的配置基本就這樣了,接下來對tomcat做些配置的修改。找到tomcat裡的conf/server.xml,註釋掉預設的Host配置,新增如下Host配置:

    <Host name="localhost" appBase="E:\tomcat\apache-tomcat-8.0.35-8082\webapps\web" deployOnStartup ="false" autoDeploy="false" unpackWARs="true">
                 <Context path="/"  docBase="E:\tomcat\apache-tomcat-8.0.35-8082\webapps\web" />
                 <Valve   className="org.apache.catalina.valves.AccessLogValve"   
                 directory="logs"     prefix="localhost_access_log"   suffix=".txt"   
                 pattern="%h %l %u %t "%r" %s %b"   />
    </Host> 

以上是windows伺服器下的配置,如為linux,只需更改appBase和docBase,指向專案的路徑。tomcat的配置也已經完成,重啟tomcat,訪問域名就指向了tomcat裡的專案。

希望能對大家有幫助,如果在使用的過程中遇到什麼問題,可以在底下留言。

我的部落格即將搬運同步至騰訊雲+社群,邀請大家一同入駐:https://cloud.tencent.com/developer/support-plan

 

相關文章