ubuntu22 docker openvpn

240610

在ubuntu22 安装docker

apt install docker

apt install docker.io

16:41 2023/8/15
OpenVPN吊销用户和增加用户-一亩三分地  https://www.qiqios.cn/279.html
https://www.qiqios.cn/279.html
./easyrsa revoke client
./easyrsa gen-crl
vi /etc/openvpn/server.conf
crl-verify /usr/share/easy-rsa/pki/crl.pem
systemctl restart openvpn.service


docker run [options] [image_name]:创建并启动一个容器。
docker ps:列出当前正在运行的容器。
docker stop [container_name/container_id]:停止一个容器。
docker rm [container_name/container_id]:删除一个容器。
docker logs [container_name/container_id]:查看容器的日志。
docker exec [options] [container_name/container_id] [command]:在容器中运行一个命令。
docker commit [container_name/container_id] [new_image_name]:将一个容器保存为一个新的镜像。
docker save [image_name] > [path/to/save]:将一个镜像保存到本地。
docker load < [path/to/image]:将一个镜像加载到Docker中。


docker search ubuntu
!!!
docker pull ubuntu
docker run -d -v /opt/registry:/var/lib/registry -p 5000:5000 --restart=always --name registry registry:latest

docker exec -it container_name /bin/bash

docker load -i /path/to/destination/file.tar.gz

-p 8080:80: 端口进行映射,将本地 8080 端口映射到容器内部的 80 端口
docker run --name nginx-test -p 8080:80 -d nginx
!!!
docker run -itd --name ubuntu-test -p 1194:1194 ubuntu

!!!
docker exec -it ubuntu-test /bin/bash
docker exec -it openvpn /bin/bash
docker exec -it openvpn-ubuntu /bin/bash


!!!
docker rmi hello-world


test
docker run --volumes-from ovpn-data --rm -p 1194:1194/udp --cap-add=NET_ADMIN kylemanna/openvpn

!!!拷贝文件
tar -xzvf openvpn-server-bak.tar.gz -C /
docker cp /etc/openvpn/ 5a37e395d597:/etc/
docker cp openvpn-ubuntu:/etc/iptables/ss.sh /etc/iptables/
docker cp /etc/iptables/ss.sh openvpn-ubuntu:/etc/iptables/ss.sh

!!!
根据image修改名称和tag
docker tag 5f0765fabe42 u:v6shenqi

docker commit [容器id] [起一个镜像名]
docker commit openvpn-ubuntu u:v7shenqi


docker save [镜像id] > [文件名.tar]
docker save -o [文件名.tar] [镜像id]
docker save -o shenqi_v7shenqi.tar u:v7shenqi
docker load  < 文件名.tar

docker自动启动!!!!!!!!!!!!!!!!
docker update --restart=always nginx-test


13:19 2024/6/10
test
docker run -itd -p 1194:1194 -p 2020:2020 --cap-add=NET_ADMIN --name u1 ubuntu "/bin/bash"
docker exec -it u1 /bin/bash

okokok!!!
神泣端口
2020-->30800
2021-->30810
docker run -itd -p 1194:1194 -p 2020:2020 --cap-add=NET_ADMIN --name u3 u:v03 "/a/ss.sh"
docker run -itd -p 1194:1194 -p 2020:2020 -p 2021:2021 --cap-add=NET_ADMIN --name openvpn-ubuntu u:v7shenqi "/etc/iptables/ss.sh"
docker run -itd -p 1194:1194 -p 2020:2020 -p 2021:2021 -p 2022:2022 -p 2023:2023 -p 2024:2024 -p 2025:2025 -p 2026:2026 --cap-add=NET_ADMIN --name openvpn-ubuntu u:v7shenqi "/etc/iptables/ss.sh"
docker exec -it openvpn-ubuntu /bin/bash


docker内的启动脚本
vi /a/ss.sh
#!/bin/bash
mkdir -p /dev/net
mknod /dev/net/tun c 10 200
chmod 600 /dev/net/tun
iptables -t nat -A POSTROUTING -s 10.8.0.0/24 -o eth0 -j MASQUERADE
cd /etc/openvpn
/usr/sbin/openvpn --config /etc/openvpn/server.conf


docker cp u1:/etc/openvpn/test230822-1.tar.gz ./


!!!!
killall
apt-get install -y psmisc
apt-get install iputils-ping
!!!!!
mkdir -p /dev/net
mknod /dev/net/tun c 10 200
chmod 600 /dev/net/tun

22:49 2024/6/9


防火墙
iptables-save > /a/rules.v4
iptables-restore < /a/rules.v4

docker 内
vvvvvvvvvvvvvvvvvvvvvv
okok!!!!!!!!!!!!!!!!
iptables -t nat -F
iptables -F INPUT
iptables -F OUTPUT
iptables -F FORWARD
iptables -t nat -A POSTROUTING -s 0/0 -j MASQUERADE
okok!!!!!!!!!!
#iptables -t nat -A POSTROUTING -s 10.8.0.0/24 -o eth0 -j MASQUERADE
#iptables -t nat -A POSTROUTING -s 10.8.0.0/24  -j MASQUERADE
http://139.224.225.186:2020

dock--test okok!!!!!!!
iptables -t nat -A PREROUTING -d 172.17.0.2 -p tcp --dport 2020 -j DNAT --to 10.8.0.6:30800
iptables -t nat -A POSTROUTING -d 10.8.0.6 -p tcp --dport 30800 -j SNAT --to 172.17.0.2:2020
iptables -t nat -A PREROUTING -d 172.17.0.2 -p tcp --dport 2021 -j DNAT --to 10.8.0.6:30810
iptables -t nat -A POSTROUTING -d 10.8.0.6 -p tcp --dport 30810 -j SNAT --to 172.17.0.2:2021

cp /etc/apt/sources.list /etc/apt/sources.list.backup
deb http://mirrors.aliyun.com/ubuntu/ jammy main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ jammy main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ jammy-updates main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ jammy-updates main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ jammy-backports main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ jammy-backports main restricted universe multiverse
deb http://mirrors.aliyun.com/ubuntu/ jammy-security main restricted universe multiverse
deb-src http://mirrors.aliyun.com/ubuntu/ jammy-security main restricted universe multiverse

okokok
更换源8:39 2024/6/10
编辑配置文件,如果文件不存在,以下命令会自动创建。
$ sudo nano /etc/docker/daemon.json

将配置信息粘贴到配置文件中,配置信息为 json 格式,可以根据实际需要设置多个国内的镜像服务器。
{
  "registry-mirrors": [
    "https://hub-mirror.c.163.com",
    "https://mirror.baidubce.com"
  ]
}

$ sudo systemctl daemon-reload 
$ sudo systemctl restart docker

$ sudo docker info

请试试这个 Dockerfile:
FROM ubuntu:16.04
RUN apt-get update && \
    apt-get clean && apt-get -y update && apt-get install -y locales curl && \
    apt-get install -y php apache2 curl openvpn zip unzip bridge-utils && \
    apt-get install nano && \
    mkdir -p /dev/net && \
    mknod /dev/net/tun c 10 200 && \
    chmod 600 /dev/net/tun
COPY tcp /etc/openvpn
EXPOSE 8888
CMD openvpn --config /etc/openvpn/Belgium.Brussels.TCP.ovpn


路由防火墙
docker iptables详解_风神修罗使的博客-CSDN博客  https://blog.csdn.net/WuLex/article/details/130193920

!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
基于Docker搭建OpenVPN服务器 | 魔のkyo的BLOG  http://www.kyo86.com/2022/10/08/openvpn/
>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
docker部署openvpn - 码农教程  http://www.manongjc.com/detail/64-rvungbvqhbiyqdz.html
docker部署openvpn
时间:2022-11-07

本文章向大家介绍docker部署openvpn,主要内容包括拉取openvpn镜像、创建目录、生成配置文件、生成密钥文件、生成客户端证书、导出客户端配置、启动openvpn、openvpn用户管理、删除用户脚本、添加用户、基本概念、基础应用、原理机制和需要注意的事项等,并结合实例形式分析了其使用技巧,希望通过本文能帮助到大家理解应用这部分内容。

拉取openvpn镜像
docker pull chenji1506/openvpn:2.4.8
创建目录
mkdir -pv /data/openvpn/conf
生成配置文件
1.1.1.1是本机的公网IP,按需改成自己的IP

docker run -v /data/openvpn:/etc/openvpn --rm chenji1506/openvpn:2.4.8 ovpn_genconfig -u udp://1.1.1.1
生成密钥文件
要求输入私钥密码

docker run -v /data/openvpn:/etc/openvpn --rm -it chenji1506/openvpn:2.4.8 ovpn_initpki
    Enter PEM pass phrase: 123456                                        # 输入私钥密码
    Verifying - Enter PEM pass phrase: 123456                            # 重新输入一次密码
    Common Name (eg: your user,host,or server name) [Easy-RSA CA]:         # 输入一个CA名称。可以不用输入,直接回车
    Enter pass phrase for /etc/openvpn/pki/private/ca.key: 123456        # 输入刚才设置的私钥密码,完成后在输入一次
生成客户端证书
chenji改成其他名字

docker run -v /data/openvpn:/etc/openvpn --rm -it chenji1506/openvpn:2.4.8 easyrsa build-client-full chenji nopass
    Enter pass phrase for /etc/openvpn/pki/private/ca.key: 123456        # 输入刚才设置的密码
导出客户端配置
docker run -v /data/openvpn:/etc/openvpn --rm chenji1506/openvpn:2.4.8 ovpn_getclient chenji > /data/openvpn/conf/chenji.ovpn
启动openvpn
docker run --name openvpn -v /data/openvpn:/etc/openvpn -d -p 1194:1194/udp --cap-add=NET_ADMIN chenji1506/openvpn:2.4.8
openvpn用户管理
添加用户脚本
vim add_user.sh

#!/bin/bash
read -p "please your username: " NAME
docker run -v /data/openvpn:/etc/openvpn --rm -it chenji1506/openvpn:2.4.8 easyrsa build-client-full $NAME nopass
docker run -v /data/openvpn:/etc/openvpn --rm chenji1506/openvpn:2.4.8 ovpn_getclient $NAME > /data/openvpn/conf/"$NAME".ovpn
docker restart openvpn
删除用户脚本
vim del_user.sh

#!/bin/bash
read -p "Delete username: " DNAME
docker run -v /data/openvpn:/etc/openvpn --rm -it chenji1506/openvpn:2.4.8 easyrsa revoke $DNAME
docker run -v /data/openvpn:/etc/openvpn --rm -it chenji1506/openvpn:2.4.8 easyrsa gen-crl
docker run -v /data/openvpn:/etc/openvpn --rm -it chenji1506/openvpn:2.4.8 rm -f /etc/openvpn/pki/reqs/"DNAME".req
docker run -v /data/openvpn:/etc/openvpn --rm -it chenji1506/openvpn:2.4.8 rm -f /etc/openvpn/pki/private/"DNAME".key
docker run -v /data/openvpn:/etc/openvpn --rm -it chenji1506/openvpn:2.4.8 rm -f /etc/openvpn/pki/issued/"DNAME".crt
docker restart openvpn
添加用户
./add_user.sh    # 输入要添加的用户名,回车后输入刚才创建的私钥密码
创建的证书在/data/openvpn/conf/目录下
<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值