| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- package main
- import (
- "fmt"
- "time"
- gps "hnyfkj.com.cn/rtu/linux/air530z"
- baseapp "hnyfkj.com.cn/rtu/linux/baseapp"
- camera1 "hnyfkj.com.cn/rtu/linux/mvs_u_takephoto" // 海康U口相机
- netmgrd "hnyfkj.com.cn/rtu/linux/netmgrd"
- "hnyfkj.com.cn/rtu/linux/sshd"
- )
- func main() {
- if baseapp.IsArgsParam("-h") {
- help()
- return
- }
- if baseapp.IsArgsParam("-v") {
- fmt.Println("程序版本:", baseapp.Version, "\n构建时间:", baseapp.BuildTime)
- return
- }
- baseapp.ModuleInit()
- baseapp.SingleInstanceRun() // 异步非阻塞
- baseapp.Logger.Infof("程序版本: %s 构建时间: %s\n程序开始运行...",
- baseapp.Version, baseapp.BuildTime)
- // 01, 初始化卫星定位模块
- gps.ModuleInit()
- // 02, 初始化4G调制解调器
- if !netmgrd.ModemInit() {
- goto end_p
- }
- // 03, 初始化网络管理模块
- netmgrd.ModuleInit()
- netmgrd.WaitAllOK(time.Duration(10) * time.Second) // 等待联网成功和网路时间同步成功
- // 04, 初始化远程运维模块, Todo: 根据项目不同, 远程运维连接的MQTT服务器不同, 具体看情况
- if err := sshd.ModuleInit("", "", ""); err != nil {
- baseapp.Logger.Warnf("初始化远程运维模块失败: %v", err)
- }
- // 05, 初始化相机拍照模块
- if !camera1.ModuleInit() {
- goto end_p
- }
- // 06, 初始化与控制板通信, Todo: 根据项目不同, 使用的控制版硬件和协议都不同, 具体看情况
- // 07, 后台服务器业务交互, Todo: 根据项目不同, 实现具体的业务逻辑协议都不同, 具体看情况
- // 08, 阻塞等待退出信号量
- <-baseapp.IsExit2()
- // 09, 退出程序并释放资源
- end_p:
- sshd.ModuleExit()
- netmgrd.ModemExit()
- gps.ModuleExit()
- baseapp.Logger.Info("程序退出")
- baseapp.ExitLogger() // 安全的关闭日志模块
- baseapp.SafeExit() // 安全的关闭退出程序
- }
- func help() {
- h := `
- -h 显示帮助提示
- -v 当前程序版本
- `
- fmt.Println(h)
- }
|