搭建Python在线开发环境(随时随地码代码)

打开浏览器,即可进行Python程序开发,开发体验可媲美桌面版的vs code,一致的开发环境(基于Ubuntu镜像)。

最终效果图

在这里插入图片描述

安装docker

  1. 删除旧版本

    for pkg in docker.io docker-doc docker-compose \
     podman-docker containerd runc; \
    do sudo apt-get remove $pkg; done
    
  2. 设置apt 仓库

    # Add Docker's official GPG key:
    sudo apt-get update
    sudo apt-get install ca-certificates curl
    sudo install -m 0755 -d /etc/apt/keyrings
    sudo curl -fsSL https://download.docker.com/linux/debian/gpg -o /etc/apt/keyrings/docker.asc
    sudo chmod a+r /etc/apt/keyrings/docker.asc
    
    # Add the repository to Apt sources:
    echo \
     "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] \
     https://mirrors.tuna.tsinghua.edu.cn/docker-ce/linux/debian \
     $(. /etc/os-release && echo "$VERSION_CODENAME") stable" | \
     sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
    sudo apt-get update
    
  3. 安装docker

    sudo apt-get install docker-ce docker-ce-cli \
       containerd.io docker-buildx-plugin docker-compose-plugin
    
  4. 验证安装

    sudo docker run hello-world
    
  5. 将用户添加到docker组

    sudo groupadd docker
    sudo usermod -aG docker $USER
    newgrp docker
    

使用docker创建开发服务器

  1. 创建项目文件夹

    mkdir code-server && cd code-server
    
  2. 创建Dockerfile

     FROM codercom/code-server:ubuntu
    
     USER root
     # 修改源
     RUN sed -i 's#http://ports.ubuntu.com/ubuntu-ports/#https://mirrors.tuna.tsinghua.edu.cn/ubuntu-ports/#g' /etc/apt/sources.list
    
     RUN apt update -y && apt upgrade -y
    
     # 设置时区
     ENV TZ="Asia/Shanghai"
     RUN DEBIAN_FRONTEND=noninteractive apt-get install -yq tzdata && \
         ln -fs /usr/share/zoneinfo/$TZ /etc/localtime && \
         dpkg-reconfigure -f noninteractive tzdata
     USER 1000
    
     ENV USER=coder
    
     WORKDIR /home/coder
    
     RUN sudo apt install build-essential libssl-dev zlib1g-dev \
             libbz2-dev libreadline-dev libsqlite3-dev curl \
             libncursesw5-dev xz-utils tk-dev libxml2-dev libxmlsec1-dev libffi-dev liblzma-dev -y
    
     # install python
     RUN curl https://pyenv.run | bash
    
     RUN export PYENV_ROOT="$HOME/.pyenv" \
         && export PATH="$PYENV_ROOT/bin:$PATH" \
         && eval "$(pyenv init -)" \
         && pylatest=$(pyenv install -l | grep -E '^  ([0-9].)([0-9]+.)([0-9]+)$' | tail -n1) \
         && pyenv install $pylatest \
         && pyenv global $pylatest \
         && python -m pip install -i https://pypi.tuna.tsinghua.edu.cn/simple --upgrade pip \
         && pip config set global.index-url https://pypi.tuna.tsinghua.edu.cn/simple \
         && echo 'export PYENV_ROOT="$HOME/.pyenv"' >> ~/.bashrc \
         && echo 'command -v pyenv >/dev/null || export PATH="$PYENV_ROOT/bin:$PATH"' >> ~/.bashrc \
         && echo 'eval "$(pyenv init -)"' >> ~/.bashrc
    
     RUN sudo apt install vim tree -y
    
     # 修改提示符显示最后一个文件夹
     RUN sed -i 's/\(PS1.*\)\\w/\1\\W/g' ~/.bashrc
    
  3. 创建docker-comose.yaml

    services:
      code-server:
        build: .
        container_name: code-server
        user: "${UID}:${GID}"
        environment:
          - DOCKER_USER=$USER
        volumes:
          - ./.config:/home/coder/.config
          - ./.local:/home/coder/.local
          - ~/code:/home/coder/workspace
          - ~/.ssh:/home/coder/.ssh
        ports:
          - 8080:8080
        restart: unless-stopped
    

    挂载~/code到容器中的/home/coder/workspace,这里可以根据自己的要求修改。

  4. 启动容器

       mkdir .config .local
       docker compose up -d
    
  5. 浏览器访问本机的8080端口,即可进入web版的vscode,登陆密码可以在./.config/code-server/config.yaml文件查看

    登陆页面

附件

python-web在线开发环境部署资源包

推荐阅读

1.【python爬虫】10行代码教你开发一个爬虫
2. pipenv的安装和使用

  • 35
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

gopyer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值