Linux配置strongSwan

简介: Linux配置strongSwan

strongSwan是一个开源的基于IPsec的VPN解决方案,最近要用到strongSwan来对接其他系统的IPsec,不能贸然行动,先在Linux环境下测试一下相同环境下如何配置。


通过上次的配置,我们现在已经有配置strongSwan的环境了,就是两台开启了IP转发功能的Linux主机。

1677234376680.jpg

安装strongSwan


strongSwan的安装还是很简单的,可以直接从yum仓库安装。

yum install -y strongswan

1677234397531.jpg

查看一下strongSwan命令,还是很简单的,只有为数不多的命令。

1677234410391.jpg

 

检查一下软件版本,可以看到使用yum安装的版本为5.7.3,而官网最新版本是5.9.5,应该差别不大吧。

1677234416003.jpg

strongSwan的默认安装路径是/etc/strongswan/,这里面比较重要的就是ipsec.conf和ipsec.secrets这两个配置文件了。这两个文件的配置指导已经过了,有需要的小伙伴可以参考()和()。

1677234425768.jpg


配置strongSwan


在ipsec.conf配置中,给了一个简单的配置实例。


conn snt
left=192.168.0.1
leftsubnet=10.1.0.0/16
right=192.168.0.2
rightsubnet=10.1.0.0/16
keyingtries=%forever
auto=add

简单理解一下,配置文件中的left表示为本端,right表示为对端;leftsubnet和rightsubnet就是对应的私网网段,如果有多个,用逗号隔开就行了,如果要指定端口号,就写到方括号里面,在(配置)中已经介绍过了。

leftsubnet=10.0.0.1[tcp/http],10.0.0.2[6/80]

keyingtries表示在放弃协商之前应该进行多少次尝试,默认值为3;auto表示IPsec在启动时应自动执行什么操作,add表示加载连接而不启动它。更推荐使用route, 表示加载连接并安装到内核,如果检测到本端子网和对端子网之间的流量,则建立连接。


在回顾一下通过IKE建立IPsec的过程,IKE为IPsec协商建立SA,并把建立的参数交给IPsec,IPsec使用IKE建立的SA对IP报文加密或认证处理。IKE协商分为两个阶段,第一阶段建立IKE SA,协商模式可分为主模式(Main Mode)和野蛮模式(Aggressive Mode);第二阶段就是快速模式(Quick Mode)。


第一阶段


如果是华三路由器,我们在第一阶段要选择协商模式,默认为主模式,strongSwan也一样,如果要使用野蛮模式,要配置aggressive = yes。


还要配置默认的安全提议,包括认证方式,我们一般配置PSK,但是strongSwan默认是带公钥的密钥,需要修改为PSK,命令为authby=psk。还要配置对端信息,常用配置命令如下:



#
ike keychain swan
 pre-shared-key address 12.1.1.2 255.255.255.0 key simple swan
#
ike profile swan
 keychain swan
 match remote identity address 12.1.1.2 255.255.255.0


放到strongSwan中,要配置2个文件,ipsec.secrets中配置预共享密钥。



vi /etc/strongswan/ipsec.secrets
12.1.1.1 12.1.1.2 : PSK swan


ipsec.conf中配置认证方式和IKE版本,指定本端和对端身份信息,因为leftid默认是取left的值,所以如果没有特殊要求,可以不必重复配置。



vi /etc/strongswan/ipsec.conf
conn swan
authby=psk
keyexchange=ikev1
left=12.1.1.1
right=12.1.1.2


再一个比较关键的配置就是算法,包括加密算法、验证算法、密钥加密算法。strongSwan中,默认的算法为ike = aes128-sha256-modp3072,其中aes128指aes-cbc-128,为加密算法;sha256就是sha256,为验证算法;modp3072为密钥加密算法。当然,这个可以直接使用默认配置。


第二阶段


如果是华三路由器,我们在第二阶段要配置IPsec策略的相关信息,比如感兴趣流ACL。在strongSwan中,是通过配置本端私网和对端私网来实现的。



#
acl advanced 3402
 rule 0 permit ip source 11.1.1.0 0.0.0.255 destination 22.1.1.0 0.0.0.255


在strongSwan中,是通过配置本端私网和对端私网来实现的。



conn swan
leftsubnet=11.1.1.0/24
rightsubnet=22.1.1.0/24


然后就是加密模式和加密算法,华三路由器默认的加密模式为ESP,默认是未采用任何加密算法的,需要手工配置。




#
ipsec transform-set swan
 esp encryption-algorithm aes-cbc-128
 esp authentication-algorithm sha1


strongSwan默认也是使用ESP,但是不像华三设备一样支持同时使用AH+ESP,仅能使用其中一种,ESP的默认加密算法-验证算法为aes128-sha256。当然,这个也可以直接使用默认配置。


再有就是报文封装模式,两者默认都是隧道(tunnel)模式,因为传输(transport)模式不符合使用场景。


如果是华三设备,还要再把配置组装一遍,像下面这样。



#
ipsec policy swan 10 isakmp
 transform-set swan
 security acl 3402
 local-address 192.168.1.216
 remote-address 192.168.1.143
 ike-profile swan
#
interface GigabitEthernet1/0
ipsec apply policy swan


但是strongSwan就不用了,前面拼完就是完整的配置文件了。ipsec.conf配置文件如下:


cat /etc/strongswan/ipsec.conf
conn swan
        authby = psk
        keyexchange=ikev1
        left=12.1.1.1
        leftsubnet=11.1.1.0/24
        right=12.1.1.2
        rightsubnet=22.1.1.0/24
        auto=route

ipsec.secrets配置文件如下:

cat /etc/strongswan/ipsec.secrets
12.1.1.1 12.1.1.2 : PSK swan

验证配置


配置完成之后启动strongSwan服务并使能开机自启。



systemctl start strongswan
systemctl enable strongswan

1677234581910.jpg

同理,配置主机Linux2。

cat /etc/strongswan/ipsec.conf
conn swan
        authby = psk
        keyexchange=ikev1
        left=12.1.1.2
        leftsubnet=22.1.1.0/24
        right=12.1.1.1
        rightsubnet=11.1.1.0/24
        auto=route
cat /etc/strongswan/ipsec.secrets
12.1.1.2 12.1.1.1 : PSK swan

直接用Host1向Host2发起ping测试。

1677234613458.jpg

可以看到,也是丢了第一个包,应该是去出发IKE SA和IPsec SA的建立了。查看strongSwan状态信息。

strongswan status

1677234627842.jpg

strongswan statusall

1677234640807.jpg

这里面,Security Associations就是安全联盟SA,后面是1的就是一阶段,也就是对应的IKE SA;后面是2的就是二阶段,也就是对应的IPsec SA。

相关文章
|
4天前
|
缓存 资源调度 安全
深入探索Linux操作系统的心脏——内核配置与优化####
本文作为一篇技术性深度解析文章,旨在引领读者踏上一场揭秘Linux内核配置与优化的奇妙之旅。不同于传统的摘要概述,本文将以实战为导向,直接跳入核心内容,探讨如何通过精细调整内核参数来提升系统性能、增强安全性及实现资源高效利用。从基础概念到高级技巧,逐步揭示那些隐藏在命令行背后的强大功能,为系统管理员和高级用户打开一扇通往极致性能与定制化体验的大门。 --- ###
19 9
|
6天前
|
存储 安全 数据管理
如何在 Rocky Linux 8 上安装和配置 Elasticsearch
本文详细介绍了在 Rocky Linux 8 上安装和配置 Elasticsearch 的步骤,包括添加仓库、安装 Elasticsearch、配置文件修改、设置内存和文件描述符、启动和验证 Elasticsearch,以及常见问题的解决方法。通过这些步骤,你可以快速搭建起这个强大的分布式搜索和分析引擎。
13 5
|
2月前
|
网络协议 安全 Linux
如何配置Linux端的ftp?
如何配置Linux端的ftp?
146 64
|
20天前
|
Java Linux 网络安全
NIFI在Linux服务区上的部署配置过程是什么?
【10月更文挑战第21天】NIFI在Linux服务区上的部署配置过程是什么?
36 2
|
1月前
|
Ubuntu Linux 编译器
Linux/Ubuntu下使用VS Code配置C/C++项目环境调用OpenCV
通过以上步骤,您已经成功在Ubuntu系统下的VS Code中配置了C/C++项目环境,并能够调用OpenCV库进行开发。请确保每一步都按照您的系统实际情况进行适当调整。
255 3
|
1月前
|
监控 安全 网络协议
快速配置Linux云服务器
【10月更文挑战第3天】快速配置Linux云服务器
|
2月前
|
Oracle Java 关系型数据库
Linux下JDK环境的配置及 bash: /usr/local/java/bin/java: cannot execute binary file: exec format error问题的解决
如果遇到"exec format error"问题,文章建议先检查Linux操作系统是32位还是64位,并确保安装了与系统匹配的JDK版本。如果系统是64位的,但出现了错误,可能是因为下载了错误的JDK版本。文章提供了一个链接,指向Oracle官网上的JDK 17 Linux版本下载页面,并附有截图说明。
Linux下JDK环境的配置及 bash: /usr/local/java/bin/java: cannot execute binary file: exec format error问题的解决
|
2月前
|
Linux 编译器 开发工具
快速在linux上配置python3.x的环境以及可能报错的解决方案(python其它版本可同样方式安装)
这篇文章介绍了在Linux系统上配置Python 3.x环境的步骤,包括安装系统依赖、下载和解压Python源码、编译安装、修改环境变量,以及常见安装错误的解决方案。
120 1
|
2月前
|
Ubuntu Linux
Linux服务器的自动启动可以在哪里进行配置?
Linux服务器的自动启动可以在哪里进行配置?
154 3
|
1月前
|
应用服务中间件 Linux Shell
Linux 配置 Nginx 服务的详细步骤,绝对干货
Linux 配置 Nginx 服务的详细步骤,绝对干货
70 0