> 백엔드 개발 > Golang > Golang이 데몬 프로세스를 생성하고 원활하게 다시 시작하는 방법을 분석합니다.

Golang이 데몬 프로세스를 생성하고 원활하게 다시 시작하는 방법을 분석합니다.

藏色散人
풀어 주다: 2021-07-23 14:25:47
앞으로
2685명이 탐색했습니다.

PHP 개발 베테랑입니다. nginx 및 PHP-FPM과 같은 작업을 시작/다시 시작/중지하기 위해 명령줄을 사용했습니다. 매우 감동받았습니다. 만약 나에게 C/C++를 사용하여 그러한 시스템을 개발하라는 요청을 받았다면 나는 그것을 할 에너지가 전혀 없었을 것입니다. 그런데 Golang이 내 시야에 들어온 이후. 나는 모든 것이 매우 쉽다는 것을 알았습니다.

1) 데몬 프로세스 생성

코드로 직접 이동:

package main

import (
    "os"
    "os/exec"
    "path/filepath"
)

func main() {
    //判 断当其是否是子进程,当父进程return之后,子进程会被 系统1 号进程接管
    if os.Getppid() != 1 {
        // 将命令行参数中执行文件路径转换成可用路径
        filePath, _ := filepath.Abs(os.Args[0])
        cmd := exec.Command(filePath, os.Args[1:]...)
        // 将其他命令传入生成出的进程
        cmd.Stdin = os.Stdin // 给新进程设置文件描述符,可以重定向到文件中
        cmd.Stdout = os.Stdout
        cmd.Stderr = os.Stderr
        cmd.Start() // 开始执行新进程,不等待新进程退出
        return
    }
}
로그인 후 복사

Linux 시스템에 익숙한 사람들은 알아야 합니다. 사용자가 만든 데몬 프로세스는 Linux 시스템의 프로세스 1번에 의해 인수됩니다. 즉, 위 코드는 Linux 시스템에서만 실행될 수 있습니다. 나는 유닉스 시스템을 사용해 본 적이 없습니다. 그러므로 구체적인 제안을 드릴 수는 없습니다.

데몬을 만드는 다른 방법이 있다는 것을 인터넷에서 봤습니다. 하지만 제 생각에는 위의 소스코드 방식만 좋은 것 같습니다. 프로젝트에 성공적으로 사용되었습니다.

예:

os.StartProcess() 创建守护进程。
syscall.RawSyscall() 创建守护进程。
로그인 후 복사

Only exec.Command는 데몬을 생성하는 가장 진보된 방법입니다. 최고의 캡슐화. 이 테스트를 사용하는 것이 좋습니다.

2) 데몬 시작/다시 시작/중지

1번 항목에서는 데몬을 성공적으로 시작했습니다. 그러나 kill 명령을 사용하여 종료할 수는 없습니다. 그런 다음 다시 시작하십시오. 따라서 우리는 업계의 전문적인 접근 방식인 신호를 사용해야 합니다.

실행 중인 모든 프로세스는 우리가 보내는 신호를 받을 수 있습니다. Linux에 대한 많은 신호가 있습니다. Google에서 Linux 신호라는 키워드를 검색할 수 있습니다.

소스 코드로 직접 이동:

package main

import "fmt"
import "os"
import "os/signal"
import "syscall"

func main() {

    // Go signal notification works by sending `os.Signal`
    // values on a channel. We'll create a channel to
    // receive these notifications (we'll also make one to
    // notify us when the program can exit).
    sigs := make(chan os.Signal, 1)
    done := make(chan bool, 1)

    // `signal.Notify` registers the given channel to
    // receive notifications of the specified signals.
    signal.Notify(sigs, syscall.SIGINT, syscall.SIGTERM)

    // This goroutine executes a blocking receive for
    // signals. When it gets one it'll print it out
    // and then notify the program that it can finish.
    go func() {
        sig := <-sigs
        fmt.Println()
        fmt.Println(sig)
        done <- true
    }()

    // The program will wait here until it gets the
    // expected signal (as indicated by the goroutine
    // above sending a value on `done`) and then exit.
    fmt.Println("awaiting signal")
    <-done
    fmt.Println("exiting")
}
로그인 후 복사

3가지 핵심 사항이 있습니다.
1) 신호 등록
2) 신호 수신
3) 신호 처리.

데몬 프로세스 생성과 세마포어 처리가 통합되어 있으면 데몬 프로세스를 관리하기 위한 명령을 구현할 수 있습니다.

더 많은 golang 관련 기술 기사를 보려면 golang튜토리얼 칼럼을 방문하세요!

위 내용은 Golang이 데몬 프로세스를 생성하고 원활하게 다시 시작하는 방법을 분석합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:jianshu.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿