登录
首页 >  Golang >  Go问答

Golang web应用程序在systemd服务中的ExecStart命令执行失败

来源:stackoverflow

时间:2024-03-01 13:03:25 249浏览 收藏

知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个Golang开发实战,手把手教大家学习《Golang web应用程序在systemd服务中的ExecStart命令执行失败》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!

问题内容

我是 golang 新手,正在尝试在我的服务器上托管一个简单的网站。

我使用的是 ubuntu 18.04

我的域根目录位于 /var/www/vhosts/mydomain.com/mydomain.com

我有一个 main.go 文件,它在浏览器中呈现一个简单的 hello world。

当我 go 从该目录运行 main.go 时,网页工作正常。

现在,我正在尝试创建一项服务,以便在关闭 shel​​l 时保持网页可用。

为此,我在 /etc/systemd/system 创建了一个名为 golangweb.service 的新 service

该文件的内容是:

[unit]
description = go server

[service]
execstart=/var/www/vhosts/mydomain.com/mydomain.com
type=simple
restart=always
restartsec=5

[install]
wantedby=multi-user.target

保存文件后,我按顺序插入以下命令:

sudo systemctl daemon-reload
sudo systemctl enable golangweb.service
sudo systemctl start golangweb.service
sudo systemctl status golangweb.service

当我尝试获取状态时,出现以下错误(我在那里修复了一些数据):

golangweb.service - Go Server
   Loaded: loaded (/etc/systemd/system/golangweb.service; enabled; vendor preset: enabl
   Active: activating (auto-restart) (Result: exit-code) since Fri xx-xx-xx 23:43:52
  **Process: xx ExecStart=/var/www/vhosts/mydomain.com/mydomain.com (code=exited, sta
 Main PID: xx (code=exited, status=203/EXEC)**

Mai xx xx:xx:xx xxxxx.xxxx.xxxx.systemd[1]: golangweb.service: Failed with re
Warning: Journal has been rotated since unit was started. Log output is incomplete or u
lines 1-8/8 (END)
● golangweb.service - Go Server
   Loaded: loaded (/etc/systemd/system/golangweb.service; enabled; vendor preset: enabled)
   Active: activating (auto-restart) (Result: exit-code) since Fri xx-xx-xx xx:xx:xx CEST; 3s ago
  Process: xx ExecStart=/var/www/vhosts/mydomain.com/mydomain.com (code=exited, status=203/EXEC)
 Main PID: xx (code=exited, status=203/EXEC)

Mai xx xx:xx:xx xxxx.xx.xx xx[1]: golangweb.service: Failed with result 'exit-code'.
Warning: Journal has been rotated since unit was started. Log output is incomplete or unavailable.

有人知道为什么会发生这种情况吗?


正确答案


execstart 的第一个参数必须是可执行文件。看来您已将其设置为目录。如果您尝试在 shell 提示符下键入 /var/www/vhosts/mydomain.com/mydomain.com,您会看到类似的行为:无法运行目录。

可以设置:

workingdirectory=/var/www/vhosts/mydomain.com/mydomain.com
execstart=/usr/bin/go run main.go

或者,您可以编译代码 (go build),然后将 execstart 设置为已编译二进制文件的完整路径:

ExecStart=/var/www/vhosts/mydomain.com/mydomain.com/compiledprogramname

今天关于《Golang web应用程序在systemd服务中的ExecStart命令执行失败》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>