构建点到点的虚拟专用网络

OpenVPN 的基本特性

使用OpenVPN ,我们可以实现以下功能

  • 对于任何IP 子网或者虚拟以太网通过一个UDP 或者 TCP 端口建立隧道。
  • 架构一个可扩展的、负载均衡的虚拟专用网络集群系统,同时支持上千用户的连接。
  • 使用任意加密算法、密钥长度或者HMAC摘要。这些功能是使用OpenSSL库来实现的。
  • 可以选择最简单的静态密码和传统加密算法或者基于证书的公钥私钥加密算法。
  • 对数据流进行实时压缩。
  • 支持对端节点通过动态方法获取IP地址,例如DHCP等。
  • 对于面向连接的有状态防火墙,不需要使用特殊的设置。
  • 支持网络地址转换。
  • 在WIndows 或者 mac OS 上面提供GUI 工具。
搭建点到点的虚拟专用网络

Open VPN 点到点(Peer- to - Peer)的虚拟专用网络的物理架构
在这里插入图片描述
操作步骤如下:
1) 这个是两台服务器同时操作的步骤

## 首先在 /usr/local 下面先建立 一个文件夹
 # 下载epel 的扩展仓库 
 wget https://dl.fedoraproject.org/pub/epel/epel-release-latest-6.noarch.rpm
 ## 安装rpm包
rpm -ivh epel-release-latest-6.noarch.rpm
## 安装openvpn 需要的依赖库(lzo 库 用于压缩;openssl 用于支持加密和证书认证)
yum - y install lzo lzo-devel openssl openssl-devel  
## 安装openvpn
yun -y install   

2 )在第一台服务器(x.y.z.100)上面生成静态密钥

 openvpn --genkey --secret key 

会在当前文件下生成一个key

3) 使用scp 把key 文件传输到对端的 xx.yy.zz.100 服务器

 scp /usr/local/openvpn/key root@xx.yy.zz.100:/usr/local/openvpn/key
### 需要输入对端服务器的密码
  1. 创建隧道
    在 x.y.z.100 服务器上执行
  openvpn --remote xx.yy.zz.100 --dev tun0 --ifconfig 10.6.0.1 10.6.0.2 --secret key --daemon

在 xx.yy.zz.100 服务器上执行

  openvpn --remote x.y.z.100 --dev tun0 --ifconfig 10.6.0.2 10.6.0.1 --secret key --daemon

–remote : 表示指定的点到点的对端地址
–dev 使用tun设备
–ifconfig 指定虚拟隧道的本端和远端IP 地址
–secret 指定静态密钥的文件
– daemon 指定使用后台驻守进程模式

5) 验证隧道功能
在 x.y.z.100 上执行

ping 10.6.0.2 -c 2  

在 xx.yy.zz.100 上使用tcpdump 查看访问

 tcpdump -vvv -nnn -i tun0 icmp
### 解析 Import Error 的常见原因 当遇到 `ImportError: cannot import name 'Generic'` 错误时,通常意味着尝试从模块中导入的对象不存在或无法访问。此问题可能由多种因素引起: - 版本不兼容:不同库之间的版本冲突可能导致此类错误。 - 安装缺失:目标库未正确安装或路径配置有误。 - 导入语句不当:可能存在循环依赖或其他语法层面的问题。 ### 针对 Generic 类型的具体解决方案 对于特定于 `Generic` 的情况,考虑到 Python 中 `Generic` 是 typing 模块的一部分,在处理该类别的 ImportError 时可采取如下措施[^1]: #### 方法一:确认typing模块可用性 确保环境中已安装标准库中的 typing 模块,并且其版本支持所使用的特性。可以通过以下命令验证: ```bash python -c "from typing import Generic; print(Generic)" ``` 如果上述命令执行失败,则可能是由于 Python 或者相关扩展包的版本过低造成的。此时应考虑升级至更高版本的解释器以及对应的开发工具链。 #### 方法二:调整导入方式 有时直接通过顶层命名空间来获取所需组件会更稳定可靠。修改代码以采用这种做法可能会解决问题: ```python from collections.abc import Iterable # 如果是迭代器相关接口 from typing import TypeVar, Protocol # 对于协议和泛型定义 T = TypeVar('T') class MyContainer(Protocol[T]): ... ``` 注意这里并没有显式提到 `Generic` ,而是利用了更为基础的数据结构抽象基类或是其他替代方案实现相同功能[^2]。 #### 方法三:排查环境变量设置 检查系统的 PYTHONPATH 和虚拟环境配置是否正常工作。任何异常都可能导致某些第三方软件包找不到必要的资源文件而引发类似的错误提示。建议清理并重建项目专属的工作区以便排除干扰项的影响。 #### 示例修正后的代码片段 假设原始代码试图这样引入 `Generic` : ```python from some_module import Generic # 可能导致 ImportError ``` 改为遵循官方文档推荐的方式后变为: ```python from typing import Generic # 正确的做法 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值