> ### 線上環境部署
* 線上服務器不需要安裝Go的開發環境, 也不用將源碼上傳上去
* 只需要找一臺和線上服務器相同的操作系統, 安裝GO環境, 上傳源碼, 生成可執行文件, 將生成的可執行文件放到線上服務器(避免線上服務器出現漏洞時, 被人盜竊源碼, 找出漏洞, 進一步遭受攻擊)
* 將本地可執行文件上傳到線上服務器時, 如果用到相對路徑, 那線上服務器放可執行文件的文件, 要和本地生成可執行文件的位置相同
> ### 準備工作
* 說明: 用supervisor
來管理不同服務間的單個或多個實例, 用nginx負載均衡到多個實例
* 定義三個服務, 端口為9001~9003, 將生成的可執行文件放到線上服務器(名稱http-login1, http-login2, http-login3)
~~~
package main
import (
"net/http"
"fmt"
)
func login(w http.ResponseWriter, r *http.Request) {
w.Write([]byte("Hello World"))
}
func main() {
http.HandleFunc("/login", login)
if err := http.ListenAndServe(":9001", nil); err != nil {
fmt.Println(err)
}
}
~~~
> 安裝 supervisor 進程管理工具
* supervisord:運行 Supervisor 時會啟動一個進程 supervisord,它負責啟動所管理的進程,并將所管理的進程作為自己的子進程來啟動,而且可以在所管理的進程出現崩潰時自動重啟。
* supervisorctl:是命令行管理工具,可以用來執行 stop、start、restart 等命令,來對這些子進程進行管理。
~~~
[root@VM_0_17_centos gopath]# yum install supervisor
[root@VM_0_17_centos gopath]# systemctl start supervisord.service
[root@VM_0_17_centos gopath]# vim /etc/supervisord.conf
//systemctl restart supervisord.service
(修改完配置沒生效的話重啟下)
//找到 ;[program:theprogramname]欄目, 在下一個欄目前添加
//相關配置說明可以看最下方的相關閱讀
[program:golang-http-login1]
command=/var/local/gopath/src/http-login1
autostart=true
autorestart=true
startsecs=10
;stdout_logfile=/usr/local/runtime.log ; 配置日記(點Name的時候可以看到對應終端輸出)
;
directory=/var/local/gopath/src ;在這個目錄下運行(程序引入靜態文件時)
[program:golang-http-login2]
command=/var/local/gopath/src/http-login2
autostart=true
autorestart=true
startsecs=10
[program:golang-http-login3]
command=/var/local/gopath/src/http-login3
autostart=true
autorestart=true
startsecs=10
[root@VM_0_17_centos gopath]# supervisorctl update
golang-http: stopped
golang-http: removed process group
golang-http-login1: added process group
golang-http-login2: added process group
golang-http-login3: added process group
#根據最新的配置文件,啟動新配置或有改動的進程,配置沒有改動的進程不會受影響而重啟。
//supervisorctl update
#啟動進程
//supervisorctl start golang-http-login1
#重啟進程
//supervisorctl restart golang-http-login1
#停止進程
//supervisorctl stop golang-http-login1
#啟動全部進程
//supervisorctl start all
#設置開機啟動
//systemctl enable supervisord.service
~~~
> ### 查看服務狀態
~~~
[root@VM_0_17_centos gopath]# supervisorctl status
golang-http-login1 RUNNING pid 15112, uptime 0:01:03
golang-http-login2 RUNNING pid 15113, uptime 0:01:03
golang-http-login3 RUNNING pid 15114, uptime 0:01:03
[root@VM_0_17_centos src]# netstat -tlnp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 2897/sshd
tcp6 0 0 :::9001 :::* LISTEN 15112/http-login1
tcp6 0 0 :::9002 :::* LISTEN 15113/http-login2
tcp6 0 0 :::9003 :::* LISTEN 15114/http-login3
~~~
> ### 訪問服務

> ### 圖形界面(修改inet\_http\_server模塊)


> ### nginx負載均衡
~~~
upstream golang-http-login
{
server 123.207.79.96:9001;
server 123.207.79.96:9002;
server 123.207.79.96:9003;
}
server
{
listen 9000;
location / {
proxy_pass http://golang-http-login;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
~~~
> ### 相關閱讀
* [supervisor的安裝與簡單介紹](https://www.cnblogs.com/Dicky-Zhang/p/6171954.html)
- 第一例 留言板
- 第二例 gRPC使用例子
- 第三例 基于go-micro做服務注冊和服務發現
- 第四例 聊天室
- 第五例 工具庫 第五例 并發安全字典
- dao
- common
- common.go
- config
- config.go
- gorm
- grom.go
- sqlx
- sqlx.go
- kafka
- kafka.go
- log
- log.go
- log2.go
- redis
- redis.go
- zookeeper
- zookeeper.go
- init
- main.go
- 第六例 原生sql操作
- 第七例 sqlx操作
- 第八例 Redis數據庫(gomodule/redigo)
- 第九例 Redis消息隊列
- 第十例 Redis集群連接
- 第十一例 Zookeeper操作
- 第十二例 Kafka操作
- 第十三例 NSQ操作
- 第十四例 二分查找
- 第十五例 交換排序 - 冒泡排序
- 第十六例 插入排序 - 直接插入排序
- 第十七例 插入排序 - 希爾排序
- 第十八例 交換排序 - 快速排序
- 第十九例 算法求解應用
- 第二十例 pprof性能分析
- 第二一例 CPU信息采集
- 第二二例 Heap信息采集
- 第二三例 Http信息采集
- 第二四例 單元測試(功能測試)
- 第二五例 基準測試(壓力測試/性能測試)
- 第二六例 gdb調試
- 第二七例 json序列化和反序列化
- 第二八例 protobuf序列化和反序列化
- 第二九例 包管理工具 go vendor
- 第三十例 包管理工具 go mod
- 第三一例 zip壓縮
- 第三二例 交叉編譯
- 第三三例 線上環境部署
- 第三四例 業務:實現固定周期維護
- 第三五例 聊天室(精簡版)
- 第三六例 并發安全字典
- 第三七例 導出Excel表格
- 第三八例 導出CSV表格
- 第三九例 聊天室(高并發)
- 第四十例 JWT (Json Web Token)
- 第四一例 雪花算法生成 Id
- 第四二例 對稱加密 AES
- 第四三例 非對稱加密 RSA
- 第四四例 簽名算法 SHA1
- 第四五例 數據庫操作 gorm
- 第四六例 數據庫操作 gorm 集合
- 數據庫連接和創建表
- 查詢 - 分頁
- 查詢所有數據
- 查詢單條數據
- 插入一條或多條數據
- 更新一條或多條數據
- 更新一條或多條數據(有零值)
- 第四七例 RSA(MD5WithRSA 算法)簽名和驗簽方式
- 第四八例 線上部署腳本
- 第四九例 Elasticsearch
- 第五十例 對象池
- 第五十一例 相關閱讀