Ubuntu Server 接入 WireGuard VPN 完整教程

Ubuntu Server 接入 WireGuard VPN 完整教程

将一台 Ubuntu 服务器作为客户端加入已有 WireGuard 网络

适用系统:Ubuntu 20.04 / 22.04 / 24.04 LTS


前言

WireGuard 是一款现代、简洁、高性能的 VPN 协议,相比 OpenVPN 和 IPSec 配置更简单,性能更优秀。本文介绍如何将一台 Ubuntu 服务器作为客户端,接入已搭建好的 WireGuard 服务端网络。

本教程适用场景:服务端已搭建完毕,并可导出客户端配置文件(包含公钥、私钥、服务端信息),无需手动生成密钥。


第一步:安装 WireGuard

Ubuntu 20.04 及以上版本内核已内置 WireGuard 模块,直接通过 apt 安装即可:

sql 复制代码
sudo apt update && sudo apt install wireguard -y

验证安装成功:

css 复制代码
wg --version

💡 Ubuntu 20.04+ 无需额外安装内核模块,开箱即用。


第二步:将配置文件传输到服务器

服务端管理后台导出的配置文件已包含所有必要信息(公钥、私钥、服务端地址等),无需手动生成密钥。

方式一:用 scp 从本机上传

在你的本地电脑上执行:

ruby 复制代码
scp client.conf user@服务器IP:/home/user/

方式二:直接在服务器上粘贴内容

SSH 登录服务器后执行:

bash 复制代码
sudo nano /etc/wireguard/wg0.conf
# 粘贴配置内容,Ctrl+O 保存,Ctrl+X 退出

第三步:移动配置文件并设置权限

如果通过 scp 上传,需要将文件移动到 WireGuard 指定目录并重命名:

bash 复制代码
# 移动并重命名到 WireGuard 目录
sudo mv ~/client.conf /etc/wireguard/wg0.conf

# 保护私钥安全(必须执行)
sudo chmod 600 /etc/wireguard/wg0.conf

💡 文件名 wg0.conf 决定了网络接口名称为 wg0,后续所有命令都依赖这个命名。如果文件叫 abc.conf,启动命令就要改为 wg-quick up abc


第四步:启动 WireGuard 连接

复制代码
sudo wg-quick up wg0

正常启动后会输出类似以下内容:

shell 复制代码
[#] ip link add wg0 type wireguard
[#] wg setconf wg0 /dev/fd/63
[#] ip -4 address add 10.0.0.x/24 dev wg0
[#] ip link set mtu 1420 up dev wg0

第五步:验证连接是否成功

查看握手状态

sql 复制代码
sudo wg show

看到 latest handshake 且时间在几秒内,说明连接成功:

yaml 复制代码
interface: wg0
  public key: xxxxxxxxxxxx
  private key: (hidden)
  listening port: xxxxx

peer: xxxxxxxxxxxx
  endpoint: 服务器IP:51820
  allowed ips: 10.0.0.0/24
  latest handshake: 3 seconds ago   ← 有这行说明连接成功
  transfer: 1.23 KiB received, 456 B sent

ping 测试内网连通性

arduino 复制代码
# ping 服务端内网 IP
ping 10.0.0.1

# ping 其他已接入的节点
ping 10.0.0.x

💡 内网 IP 地址以配置文件中的 Address 字段为准。


第六步:设置开机自启

确保服务器重启后自动重新连接 VPN:

perl 复制代码
# 设置开机自启
sudo systemctl enable wg-quick@wg0

# 确认状态
sudo systemctl status wg-quick@wg0

常用管理命令速查

perl 复制代码
sudo wg-quick up wg0                  # 启动
sudo wg-quick down wg0                # 停止
sudo wg show                          # 查看连接状态
sudo systemctl restart wg-quick@wg0  # 重启
sudo systemctl status wg-quick@wg0   # 查看服务状态

总结

整个流程非常简洁,核心步骤只有四步:

  1. 安装 WireGuard
  2. 将配置文件放到 /etc/wireguard/wg0.conf
  3. 执行 wg-quick up wg0 启动
  4. wg show 确认握手成功

得益于服务端直接导出配置文件,整个接入过程无需手动生成密钥或编写配置,5 分钟内即可完成。

相关推荐
SPC的存折7 小时前
1、Redis数据库基础
linux·运维·服务器·数据库·redis·缓存
爱学习的小囧8 小时前
VMware ESXi 6.7U3v 新版特性、驱动集成教程和资源包、部署教程及高频问答详情
运维·服务器·虚拟化·esxi6.7·esxi蟹卡驱动
小疙瘩8 小时前
只是记录自己发布若依分离系统到linux过程中遇到的问题
linux·运维·服务器
dldw7778 小时前
IE无法正常登录windows2000server的FTP服务器
运维·服务器·网络
运维有小邓@9 小时前
什么是重放攻击?如何避免成为受害者?
运维·网络·安全
汤愈韬9 小时前
下一代防火墙通用原理
运维·服务器·网络·security
IMPYLH10 小时前
Linux 的 od 命令
linux·运维·服务器·bash
Kk.080211 小时前
Linux(十一)fork实例练习、文件操作示例及相关面试题目分享
linux·运维·算法
数据雕塑家11 小时前
Linux下大文件切割与合并实战:解决FAT32文件系统传输限制
linux·运维·服务器
IMPYLH12 小时前
Linux 的 nice 命令
linux·运维·服务器·bash