docker运行code-servre并配置https通信

code-server 可以在浏览器中运行,使得开发者可以随时随地通过网络访问自己的开发环境,无需局限于某一台设备。只要有浏览器和网络连接,就可以继续编写代码和调试项目,非常适合远程办公和移动办公的需求。

由于每次启动code-server都要重新配置环境和插件,为了方便,我这里直接封装了一套,包含简单的 bash插件简体中文以及主题美化

拉取容器 (容器版本v4.95.1)

bash 复制代码
__run_vscode_server() {
    _name="code-server"
    docker rm -f "$_name" 2>/dev/null
    _password=$(date +%s%N | md5sum | cut -c 1-32)
    {
        # 镜像准备
        _image1="registry.cn-hangzhou.aliyuncs.com/qingtongqingc/node-app:v4.95.1-t241108"
        _image2="$(echo "$_image1" | awk -F '/' '{print $NF}')"
        if [[ "$(docker images "$_image2" | wc -l)" != "2" ]]; then
            docker pull $_image1 && docker tag "$_image1" "$_image2"
        fi
    }

    docker run -d --name "$_name" \
        --user=root \
        -p 8989:8080 \
        -e PASSWORD="$password" \    #也可以自己直接指定密码
        -v /data/workspace:/root/workspace \
        -v /ssl/qingtongqing.cc_nginx:/certs \  #请根据自己的证书路径修改
        --privileged \
        --workdir=/root/workspace \
        --restart=always \
        --runtime=runc \
        "$_image2" \
        --cert /certs/qingtongqing.cc_bundle.pem \
        --cert-key /certs/qingtongqing.cc.key

        #查看密码
        sleep 4s && echo -e "\n登陆密码:"
        docker exec -it "$_name" cat /root/.config/code-server/config.yaml | grep password:
        #指定密码后,环境变量会将明文密码哈希以后的值存入文件中,这时的密码属于加密的
}
__run_vscode_server

如果你想在自定义更丰富的参数的话,也可以手动拉取容器后,自行拉起

bash 复制代码
docker pull registry.cn-hangzhou.aliyuncs.com/qingtongqingc/node-app:v4.95.1-t241108

最后效果

如果不合适也可以根据自己的编程习惯重新封装

相关推荐
x县豆瓣酱1 小时前
【第四节】ubuntu server安装docker
linux·ubuntu·docker
伊成2 小时前
docker安装Consul笔记
笔记·docker·consul
yqcoder3 小时前
13. https 是绝对安全的吗
网络协议·安全·https
憨堡包^—^3 小时前
Docker —— MySQL主从复制集群
mysql·docker·容器
潘晓可7 小时前
Docker部署Nginx代理多个服务:公网域名与内网IP场景全解
nginx·docker·nginx proxy
素雪风华10 小时前
Jenkins+Gitee+Docker容器化部署
java·docker·gitee·jenkins·springboot·持续部署
蓝天居士10 小时前
docker常用命令集(2)
docker·容器
panamera1210 小时前
云端docker小知识
运维·docker·容器
不7夜宵13 小时前
HTTP和HTTPS部分知识点
网络协议·http·https