当前位置:   article > 正文

vscode+docker搭建迷你开发环境。制作docker镜像,并通过vscode连接后进行开发_vscode docker

vscode docker

制作自己的docker镜像,将docker镜像作为服务器,接受vscode连接

目录

1. 制作开发环境镜像

1.1 选择基础镜像

1.2 编写dockerfile

1.3 构建镜像

2. 启动镜像

3. 添加用户

3.1 查看物理机上用户信息

3.2 登录到docker中

3.3 按照物理机的用户和组id增加用户

4. 使用vscode连接

4.1 vscode添加ssh配置

4.2 vscode连接docker

4.3 打开工作目录

4.4 查看共享目录

然后就是下载代码并开始后续的开发工作了


分 4 步

  • (1)制作ubuntu20.04的开发环境

  • (2)启动镜像实例,将其作为开发环境

  • (3)添加用户(权限对齐物理开发机),可访问宿主开发机目录

  • (4)通过ssh或者vscode远程登录

1. 制作开发环境镜像

1.1 选择基础镜像

在dockerhub上找基础镜像 Docker Hub

这里以ubuntu20.04为例

1.2 编写dockerfile

基于ubuntu20.04的基础镜像,安装C++开发工具

  1. FROM ubuntu:20.04 AS ubuntu20.04-base
  2. LABEL author="authorname"
  3. ENV DEBIAN_FRONTEND=noninteractive
  4. 1. 基础环境
  5. 1.1 切换国内源
  6. RUN sed -i s@/archive.ubuntu.com/@/mirrors.tuna.tsinghua.edu.cn/@g /etc/apt/sources.list
  7. RUN apt-get clean && apt-get update
  8. 1.2 安装基础包
  9. RUN apt-get -yq install apt-utils vim git tmux bash-completion \
  10.     curl sudo locales gnupg lsb-release language-pack-zh-hans \
  11.     python3-pip openssh-server
  12. 1.3 语言
  13. RUN locale-gen en_US en_US.UTF-8
  14. RUN update-locale LC_ALL=en_US.UTF-8 LANG=en_US.UTF-8
  15. ENV LANG=en_US.UTF-8
  16. 1.4 添加docker和root用户
  17. SHELL ["/bin/bash""-o""pipefail""-c"]
  18. RUN useradd -rm -d /home/docker -s /bin/bash -g root -G sudo docker
  19. RUN echo 'docker:docker' | chpasswd
  20. RUN echo 'root:Aa123456' | chpasswd
  21. USER docker
  22. WORKDIR /home/docker
  23. 2. 安装ssh服务
  24. FROM ubuntu20.04-base AS ubuntu20.04-base-sshd
  25. USER root
  26. 2.1 ssh服务配置
  27. # SSH login fix. Otherwise user is kicked off after login
  28. RUN sed 's@session\s*required\s*pam_loginuid.so@session optional pam_loginuid.so@g' -i /etc/pam.d/sshd
  29. RUN sed -i 's/\#PubkeyAuthentication\ yes/PubkeyAuthentication\ yes/' /etc/ssh/sshd_config && \
  30.     sed -i 's/\#PasswordAuthentication\ yes/PasswordAuthentication\ yes/' /etc/ssh/sshd_config && \
  31.     sed -i 's/\#X11Forwarding\ no/X11Forwarding\ yes/' /etc/ssh/sshd_config && \
  32.     sed -i 's/\#AllowTcpForwarding\ yes/AllowTcpForwarding\ yes/' /etc/ssh/sshd_config && \
  33.     sed -i 's/\#AllowAgentForwarding\ yes/AllowAgentForwarding\ yes/' /etc/ssh/sshd_config
  34. RUN mkdir /var/run/sshd
  35. RUN bash -c 'install -m755 <(printf "#!/bin/sh\nexit 0") /usr/sbin/policy-rc.d'
  36. RUN ex +'%s/^#\zeListenAddress/\1/g' -scwq /etc/ssh/sshd_config
  37. RUN ex +'%s/^#\zeHostKey .*ssh_host_.*_key/\1/g' -scwq /etc/ssh/sshd_config
  38. RUN RUNLEVEL=1 dpkg-reconfigure openssh-server
  39. RUN ssh-keygen -A -v
  40. RUN update-rc.d ssh defaults
  41. 3. sudo配置
  42. RUN ex +"%s/^%sudo.*$/%sudo ALL=(ALL:ALL) NOPASSWD:ALL/g" -scwq! /etc/sudoers
  43. FROM ubuntu20.04-base-sshd AS ubuntu20.04-dev
  44. 4. ssh指纹可免密登录
  45. Generate and configure user keys.
  46. USER docker
  47. WORKDIR /home/docker
  48. RUN ssh-keygen -t rsa -b 4096 -C "xxx@gmail.ai" -f ~/.ssh/id_rsa_xxx_gmail -q -N ""
  49. 5. 基础开发环境
  50. # 更新镜像的包索引并安装必要的软件包
  51. RUN sudo apt-get install -yq \
  52.     cmake \
  53.     g++ \
  54.     gdb \
  55.     pkg-config
  56. 6. 默认启动命令
  57. ENTRYPOINT sudo service ssh restart && bash

1.3 构建镜像

构建带有C++开发环境的新镜像

docker build -t myubuntu20.04:0.1 .

2. 启动镜像

  • 将docker的ssh端口22映射到物理机的2222

  • 将docekr的/mnt目录映射到物理机的/mnt/users/software目录

docker run -d -t -p 2222:22 --name ubuntu20.04_for_software -v /mnt:/mnt/users/software myubuntu20.04:0.1

3. 添加用户

为了保证docker机和开发机的用户权限一致,我们需要按照权限添加用户

假设现在要将用户名为cpf的用户添加到docker中,为了docker中用户能够访问物理机的目录,我们保证docker中的用户和物理机用户在同一组内

3.1 查看物理机上用户信息

在开发机上查看用户cpf的用户信息

  1. # 有root权限可以直接查看
  2. cat /etc/passwd | grep cpf
  3. # 无root权限,用户登录后查看
  4. id -u && id -g

3.2 登录到docker中

制作镜像的时候已经在docker里增加了docker用户,因此直接使用docker用户登录

  1. # 在docker所在的物理机可以通过两种方式登录到docker中
  2. 1. 通过docker命令登录:docker exec -it ubuntu20.04_for_software /bin/bash
  3. 2. 通过ssh登录
  4. ssh docker@127.0.0.1 -p2222
  5. # 在其他设备上也可以通过ssh登录,10.31.2.204为docker所在物理机的IP地址
  6. ssh docker@10.31.2.204 -p2222

3.3 按照物理机的用户和组id增加用户

  1. 1. 以用户和组id为1000来添加cpf用户到cpf组
  2. sudo groupadd cpf -g 1000
  3. sudo useradd -g cpf -ms /bin/bash cpf -u 1000
  4. 2. 如果需要sudo权限
  5. # sudo usermod -aG sudo cpf
  6. 3. 修改cpf用户的密码
  7. # 删除原密码
  8. sudo passwd -d cpf
  9. # 切换到cpf并修改密码
  10. sudo su - cpf
  11. passwd

4. 使用vscode连接

4.1 vscode添加ssh配置

点击图标

添加配置并保存

4.2 vscode连接docker

刷新后连接

输入密码并回车

连接成功后点击添加目录

4.3 打开工作目录

点击打开文件夹,然后输入文件夹,默认是打开home目录

4.4 查看共享目录

打开终端

docker中查看目录

然后就是下载代码并开始后续的开发工作了

一起学习,一起进步

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/爱喝兽奶帝天荒/article/detail/782641
推荐阅读
相关标签
  

闽ICP备14008679号