98 lines
2.3 KiB
Bash
Executable File
98 lines
2.3 KiB
Bash
Executable File
#!/bin/sh
|
|
|
|
ACTION=${1}
|
|
shift 1
|
|
|
|
do_install() {
|
|
local path=`uci get bmtedge.@bmtedge[0].cache_path 2>/dev/null`
|
|
local uid=`uci get bmtedge.@bmtedge[0].uid 2>/dev/null`
|
|
local image_name=`uci get bmtedge.@bmtedge[0].image_name 2>/dev/null`
|
|
|
|
if [ -z "$path" ]; then
|
|
echo "path is empty!"
|
|
exit 1
|
|
fi
|
|
|
|
[ -z "$image_name" ] && image_name="jinshanyun/jinshan-x86_64:latest"
|
|
echo "docker pull ${image_name}"
|
|
docker pull ${image_name}
|
|
docker rm -f bmtedge
|
|
|
|
local cmd="docker run --restart=unless-stopped -d \
|
|
--privileged \
|
|
--network=host \
|
|
--dns=127.0.0.1 \
|
|
--tmpfs /run \
|
|
--tmpfs /tmp \
|
|
-v \"$path:/data/ksc1\" \
|
|
-v \"$path/containerd:/var/lib/containerd\" \
|
|
-e ksc_supplier_code=\"92101\" \
|
|
-e ksc_datadir=\"/data/ksc1\" \
|
|
-e ksc_machine_code=\"lsyK17032_$uid\" \
|
|
-e ksc_refer=\"ruiyun_node\""
|
|
|
|
local tz="`uci get system.@system[0].zonename`"
|
|
[ -z "$tz" ] || cmd="$cmd -e TZ=$tz"
|
|
|
|
cmd="$cmd --name bmtedge \"$image_name\""
|
|
|
|
echo "$cmd"
|
|
eval "$cmd"
|
|
|
|
if [ "$?" = "0" ]; then
|
|
if [ "`uci -q get firewall.bmtedge.enabled`" = 0 ]; then
|
|
uci -q batch <<-EOF >/dev/null
|
|
set firewall.bmtedge.enabled="1"
|
|
commit firewall
|
|
EOF
|
|
/etc/init.d/firewall reload
|
|
fi
|
|
fi
|
|
|
|
echo "Install OK!"
|
|
|
|
}
|
|
|
|
usage() {
|
|
echo "usage: $0 sub-command"
|
|
echo "where sub-command is one of:"
|
|
echo " install Install the bmtedge"
|
|
echo " upgrade Upgrade the bmtedge"
|
|
echo " rm/start/stop/restart Remove/Start/Stop/Restart the bmtedge"
|
|
echo " status Onething Edge status"
|
|
echo " port Onething Edge port"
|
|
}
|
|
|
|
case ${ACTION} in
|
|
"install")
|
|
do_install
|
|
;;
|
|
"upgrade")
|
|
do_install
|
|
;;
|
|
"rm")
|
|
docker rm -f bmtedge
|
|
if [ "`uci -q get firewall.bmtedge.enabled`" = 1 ]; then
|
|
uci -q batch <<-EOF >/dev/null
|
|
set firewall.bmtedge.enabled="0"
|
|
commit firewall
|
|
EOF
|
|
/etc/init.d/firewall reload
|
|
fi
|
|
;;
|
|
"start" | "stop" | "restart")
|
|
docker ${ACTION} bmtedge
|
|
;;
|
|
"status")
|
|
docker ps --all -f 'name=bmtedge' --format '{{.State}}'
|
|
;;
|
|
"port")
|
|
docker ps --all -f 'name=bmtedge' --format '{{.Ports}}' | grep -om1 '0.0.0.0:[0-9]*' | sed 's/0.0.0.0://'
|
|
;;
|
|
*)
|
|
usage
|
|
exit 1
|
|
;;
|
|
esac
|
|
|