Supervisor 维护 Go进程

南楼画角 提交于 2020-03-09 11:38:12

 

 

首先关于supervisor的介绍就不说了,直接进入正题。

supervisor安装

sudo yum install python-setuptools
sudo easy_install supervisor

安装成功后 生成配置文件

sudo echo_supervisord_conf > /etc/supervisord.conf

出现问题:permission denied: /etc/supervisord.conf

解决方式: sudo su - root -c "echo_supervisord_conf > /etc/supervisord.conf"   

 

添加项目配置文件

为了文件的整洁性,我们统一将文件放到新建的/etc/supervisorconffile的文件夹下,再次文件夹下,建立各种(如.conf)文件。

 

修改主配置文件

编辑/etc/supervisord.conf 在文件最后修改:

原来

;[include]
;files = relative/directory/*.ini

改为

[include]
files = /etc/supervisorconffile/*.conf

如果使用的不是.conf文件,那么就根据自定义的文件后缀修改.

 

启动

首先声明,此处并没将supervisor进程加入到init.d中。

sudo /usr/bin/supervisord -c /etc/supervisord.conf

出现问题: Error: Another program is already listening on a port that one of our HTTP servers is configured to use. Shut this program down first before starting supervisord.

解决方法:

1.
find / -name supervisor.sock
2.
unlink /***/supervisor.sock

再次执行以上命令,如果无任何输出就表示成功。

到此关于supervisor的安装启动,就完成了,下面我们来做一个go项目练练手。

 

Go项目文件

    服务程序

        demo/main.go内容:

package main

import (
    "fmt"
    "log"
    "net/http"
    "strings"
)

func sayhelloName(w http.ResponseWriter, r *http.Request) {
    r.ParseForm()       //解析参数,默认是不会解析的
    fmt.Println(r.Form) //这些信息是输出到服务器端的打印信息
    fmt.Println("path", r.URL.Path)
    fmt.Println("scheme", r.URL.Scheme)
    fmt.Println(r.Form["url_long"])
    for k, v := range r.Form {
        fmt.Println("key:", k)
        fmt.Println("val:", strings.Join(v, ""))
    }
    fmt.Fprintf(w, "Hello astaxie!") //这个写入到w的是输出到客户端的
}

func main() {
    http.HandleFunc("/", sayhelloName)       //设置访问的路由
    err := http.ListenAndServe(":9090", nil) //设置监听的端口
    if err != nil {
        log.Fatal("ListenAndServe: ", err)
    }
}

    首先保证9090端口没有被占用,可自定义修改。

    go build后,将二进制文件上传至服务器。

 

   项目配置文件

在/etc/supervisorconffile/下添加demo.conf( 配置文件名自定义 ):

[program:demo]
user=root
command=/opt/Go/bin/demo
autostart=true
autorestart=true
startsecs=10
stdout_logfile=/opt/LogFile/log/demo.log 
stdout_logfile_maxbytes=1MB
stdout_logfile_backups=10
stdout_capture_maxbytes=1MB
stderr_logfile=/opt/LogFile/err/demo.log
stderr_logfile_maxbytes=1MB
stderr_logfile_backups=10
stderr_capture_maxbytes=1MB
stopsignal=INT
[supervisord]

说明

command:表示运行的命令,我这是填写的我demo安装包的原则路径。
autostart:表示是否跟随supervisor一起启动。
autorestart:如果该程序挂了,是否重新启动。
stdout_logfile:终端标准输出重定向文件。
stderr_logfile:终端错误输出重定向文件

所有文件必须提前创建好。

执行 supervisorctl update 更新新的配置到supervisord。

可以输入命令查看下刚刚启动的demo服务是否是成功

sudo supervisorctl status demo

 

 

常用命令

更新新的配置到supervisord

supervisorctl update

重新启动配置中的所有程序

supervisorctl reload

启动某个进程(program_name=你配置中写的程序名称)

supervisorctl start program_name

查看正在守候的进程

supervisorctl

停止某一进程 (program_name=你配置中写的程序名称)

pervisorctl stop program_name

重启某一进程 (program_name=你配置中写的程序名称)

supervisorctl restart program_name

停止全部进程

supervisorctl stop all

 

 

web管理supervisortd各进程

第一:修改配置文件。supervisord.conf

将最前面的";"分号都去掉。

[inet_http_server]         ; inet (TCP) server disabled by default
port=192.168.11.112:9001        ; (ip_address:port specifier, *:port for all iface)
username=username              ; (default is no username (open server))
password=password               ; (default is no password (open server))

注意ip,如果需要外网访问,直接使用*:9001即可。其次还要注意防火墙的限制.

第二:重启supervisord,执行supervisorctl reload即可。

第三:在WEB下访问你上面的port。 http://localhost:9090

 

 

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!