golang代码中调用Linux命令
短信预约 -IT技能 免费直播动态提醒
目录
- 传统方案--crontab
- 分布式任务调度
- go执行shell命令
- 实际我们在golang代码中调用linux命令
- 1、普通调用
- 2、结合协程调用,可控制中断调用
传统方案--crontab
- 缺点
- 配置任务时,需要SSh登录脚本服务器进行操作
- 服务器宕机,任务将终止调度,需要人工迁移
- 排查问题低效,无法方便的查看任务状态与错误输出
分布式任务调度
- 优点
- 可视化Web后台,方便进行任务管理
- 分布式架构、集群化调度,不存在单点故障
- 追踪任务执行状态,采集任务输出,可视化log查看
go执行shell命令
1、执行程序:/usr/bin/python start.py
2、调用命令: cat nginx.log | grep "2022"
- bash模式
- 交互模式:ls -l
- 非交互模式:/bin/bash -c "ls -l" ------ 我们使用这个
- bash模式
实际我们在golang代码中调用Linux命令
1、普通调用
package main
import (
"fmt"
"
2、结合协程调用,可控制中断调用
package main
import (
"context"
"fmt"
"os/exec"
"time"
)
// 接收子协程的数据,协程之间用chan通信
type result struct {
output []byte
err error
}
func main() {
// 执行一个cmd,让他在一个携程里面执行2s,
// 1s的时候 杀死cmd
var (
ctx context.Context
cancelFunc context.CancelFunc
cmd *exec.Cmd
resultChan chan *result
res *result
)
// 创建一个结果队列
resultChan = make(chan *result, 1000)
ctx, cancelFunc = context.WithCancel(context.TODO())
// 起一个协程
go func() {
var (
output []byte
err error
)
// 生成命令
cmd = exec.CommandContext(ctx, "bash", "-c", "sleep 3;echo hello;")
// 执行命令cmd.CombinedOutput(),且捕获输出
output, err = cmd.CombinedOutput()
// 用chan跟主携程通信,把任务输出结果传给main协程
resultChan <- &result{
err: err,
output: output,
}
}()
// Sleep 1s
time.Sleep(time.Second * 1)
// 取消上下文,取消子进程,子进程就会被干掉
cancelFunc()
// 从子协程中取出数据
res = <-resultChan
// 打印子协程中取出数据
fmt.Println(res.err)
fmt.Println(string(res.output))
}
到此这篇关于golang代码中调用Linux命令的文章就介绍到这了,更多相关golang调用Linux命令内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341