`
aiou
  • 浏览: 196920 次
  • 性别: Icon_minigender_1
  • 来自: 苏州
社区版块
存档分类
最新评论

使用SSH建立基于Linux/Unix的VPN网络

阅读更多
http://it.sohu.com/2004/03/17/47/article219474714.shtml
使用SSH建立基于Linux/Unix的VPN网络
  这里我们将要使用两台BSD、Linux或Unix服务器,在地理上相隔很远的局域网之间,通过Internet创建一条不对称的VPN连接。这两个基于Linux/Unix的VPN系统均作为网络互联路由器运行。

  所谓非对称VPN是指只有一端可以发起VPN连接,即一端具有静态IP地址,另一端具有动态IP地址,动态IP端发起VPN连接。

  网络结构与环境

  1.网络结构示意图

  网络结构如图1所示。

  

  图1 网络结构图

  

  2.本文假设如下网络环境:

  ◆ 中心VPN服务器

  主机名:server1

  外部IP地址:208.198.14.212

  局域网IP地址:192.168.3.14

  本地网络:192.168.3.0/24

  本地默认网关:192.168.3.1

  VPN名:vpngate1

  VPN IP:10.0.0.1

  ◆ 远端VPN服务器

  主机名:server2

  互联网地址动态获取

  局域网IP地址:192.168.5.18

  本地网络:192.168.5.0/24

  本地默认网关:192.168.5.1

  VPN名:vpngate2

  VPN IP:10.0.0.2

  两台机器均正确配置,能正常访问本地局域网和互联网,并且两台机器均正确安装SSH。

  3.软件

  需安装以下软件:

  ◆ pppd Linux一般已经默认安装。如果没有安装,请使用安装光盘进行安装。

  ◆ OpenSSH Linux一般已经安装。如果没有安装,请使用安装光盘进行安装。欲了解更多内容,可参见http://www.openssh.com/站点。

  ◆ pty-redir 可从ftp://ftp.vein.hu/pub/ssa/contrib/mag/pty-redir-0.1.tar.gz和http: //bleu.west.spy.net/~dustin/soft/pty-redir-0.1.tar.gz站点下载、安装。

  ◆ ssh-ip-tunnel 可从http://bleu.west.spy.net/~dustin/soft/vpn-1.0.tar.gz站点下载、安装。

  准备工作

  1.创建VPN账号

  首先在两台服务器上分别添加VPN账号。以root身份创建账号vpnusers,并创建~/.ssh目录:

  

$ su -
# useradd -m -c "VPN User" vpnuser
# mkdir /home/vpnuser/.ssh


  在Linux环境下如果使用useradd添加用户,而不为其设立密码,则该账号是一个锁定的账号,所以vpnuser账号应该是一个被锁定的账号。

  2.添加VPN的IP信息

  在两台服务器上分别将VPN的PPP接口所使用的IP地址添加到文件/etc/hosts中。内容如下:

  

10.0.0.1   vpngate1
10.0.0.2   vpngate2

  并在server2上添加server1的外部IP地址到文件/etc/hosts中。内容如下:

 

208.198.14.212   server1

  配置

  1.配置SSH

  (1)配置sshd

  在中心服务器server1上修改sshd服务器的配置,允许其使用公钥方式的认证(Public Key Authentication)。

  以root身份编辑文件:

 

$ su -
# vi /etc/ssh/sshd_config


  删除下面一行最前面的注释符号“#”:

  

#PubkeyAuthentication yes


  改为:

  

PubkeyAuthentication yes


  (2)创建和交换SSH密钥

  在server1上以root身份为vpnuser创建SSH密钥:

 

$ su -
# /usr/bin/ssh-keygen -t dsa -f /home/vpnuser/.ssh/id_dsa -C vpnuser@vpngate1 -N ''
# /usr/bin/ssh-keygen -t rsa -f /home/vpnuser/.ssh/id_rsa -C vpnuser@vpngate1 -N ''


  在vpngate2上以root身份为vpnuser创建SSH密钥:

 

$ su -
# /usr/bin/ssh-keygen -t dsa -f /home/vpnuser/.ssh/id_dsa -C vpnuser@vpngate2 -N ''
# /usr/bin/ssh-keygen -t rsa -f /home/vpnuser/.ssh/id_rsa -C vpnuser@vpngate2 -N ''


  这里使用“-N ''”参数来产生空passphrases的密钥,因为通过脚本管理VPN连接,无需手工干预。

  (3)安装授权密钥

  在server1上以root身份将公钥连接到文件public_keys.vpngate1中:

 

# cat /home/vpnuser/.ssh/id_*.pub > /home/vpnuser/.ssh/public_keys.vpngate1

  在server2上以root身份将公钥连接到文件public_keys.vpngate2中:

  

# cat /home/vpnuser/.ssh/id_*.pub > /home/vpnuser/.ssh/public_keys.vpngate2


  分别将两系统的publi_keys文件拷贝到对方机器的/home/vpnuser/.ssh目录中。并在两系统上将public_keys文件连接为一个授权密钥(authorized_keys)文件:

 

# cat /home/vpnuser/.ssh/public_keys.* > /home/vpnuser/.ssh/authorized_keys
# cat /home/vpnuser/.ssh/public_keys.* > /home/vpnuser/.ssh/authorized_keys2


  最后在两台机器上正确设置访问~/.ssh目录的访问权限和文件属主:

 

# chown -R vpnuser /home/vpnuser/.ssh
# chmod 600 /home/vpnuser/.ssh/*
# chmod 644 /home/vpnuser/.ssh/*.pub


  2.配置隧道

  软件ssh-ip-tunnel以前被称为vpn,由于该名字容易引起歧义,因此被重新更名为ssh-ip-tunnel。如果希望得到更详细的帮助,请使用man vpn。

  ssh-ip-tunnel的配置文件位于/usr/local/etc/vpn/peers目录下。在server1上创建配置文件。因为server1作为服务器在运行,并不发出VPN连接请求,因此其配置文件较简单。内容如下:

  

#/usr/local/etc/peers/vpngate2
SSHUSER=vpnuser


  server2的配置文件相对复杂,内容如下:

 

#/usr/local/etc/peers/vpngate1
SSH="/usr/bin/ssh -2"
PEER=server1
SSHUSER=vpnuser
RSAKEY=/home/vpnuser/.ssh/id_rsa
LOCALPPP=/usr/sbin/pppd
LPPPOPTIONS="call vpngate1"
REMOTEPPP=/usr/sbin/pppd
RPPPOPTIONS="call vpngate2"

  3.配置PPP

  首先在server1上创建PPP配置文件:

# /etc/ppp/vpngate2
#debug debug debug debug debug
mtu 1500
mru 1500
noauth
noipv6
10.0.0.1:10.0.0.2
netmask 255.255.255.0
linkname vpngate2
ipparam 192.168.5.0 # Network on other side of vpngate2


   再在server2上创建PPP配置文件如下:

# /etc/ppp/vpngate1 -- Remote VPN Server
#debug debug debug debug debug
mtu 1500
mru 1500
noauth
noipv6
netmask 255.255.255.0
linkname vpngate1
ipparam 192.168.3.0 # Network on other side of vpngate1
silent


   可以看到VPN连接使用的PPP接口地址是在server1的配置文件中指定的。

  测试

  在server2上将root身份切换为vpnuser身份,并连接到server1上来进行测试。命令如下:

 

# su vpnuser
$ ssh -2 vpnuser@server1


  如果是第一次连接server1,系统会出现提示问题,这里回答“yes”以便继续连接,登录成功后会得到一个Shell。

  然后以root身份在server2上,测试到server1的VPN连接,命令如下:

 

# vpn vpngate1 authtest


         监控

  下面的vpnchk脚本是实现VPN连接监控的。一旦连接断开,脚本会自动重新连接VPN,以保证VPN连接的可靠性。

#!/bin/sh
# vpnchk -- Monitor VPN Connection and restart as necessary.
# A single parameter is required:  vpnchk
# Ping REMOTE_VPN_HOST approximately every 10 seconds. Keep track of
# failed pings by incrementing COUNT.  If pings are good, always reset
# COUNT back to zero.  Only take corrective action when the number of
# failed pings reaches THRESH(hold).  Notify root by mail whenever the
# status of the vpn connection has changed.
#
REMOTE_VPN_HOST=${1}
MAILTO=root@localhost
#
if [ "${REMOTE_VPN_HOST}" = "" ]; then
  echo "Syntax: vpnchk "
  exit
fi
#
CHK_TEXT="call ${REMOTE_VPN_HOST}"
THRESH=3
COUNT=0
while [ : ]; do  # loop forever
  if ping -c 5 ${REMOTE_VPN_HOST} 1>/dev/null 2>/dev/null ; then
    COUNT=0
    if [ -f /tmp/.vpn-down ]; then
      rm -f /tmp/.vpn-down
      MSG="VPN Connection is -UP-: `date "+%H:%M on %m/%d/%Y"`"
      echo ${MSG} | mailx -s"${MSG}" ${MAILTO}
    fi
  else
    COUNT=`expr ${COUNT} + 1`
    if [ ${COUNT} -ge ${THRESH} ]; then
      if [ ! -f /tmp/.vpn-down ]; then
        touch /tmp/.vpn-down
        MSG="VPN Connection is DOWN: `date "+%H:%M on %m/%d/%Y"`"
        echo ${MSG} | mailx -s"${MSG}" ${MAILTO}
      fi
      PID=`ps -awwjx | grep -v grep | grep "${CHK_TEXT}" | awk '{print $2}'`
      if [ ! "${PID}" = "" ]; then
        for xPID in ${PID} ; do kill -KILL ${PID} ; done
        COUNT=0
        sleep 60
      fi
      nohup /usr/pkg/sbin/vpn fire start &
      sleep 150
    fi
  fi
  sleep 10
done
# end


   将该vpnchk脚本安装在目录/usr/local/sbin下,在server2上以root身份运行下面的命令来启动VPN。

  

# /usr/local/sbin/vpnchk vpngate1


  创建网络路由

  为了实现正确的路由,系统必须支持IP转发,即:

  

/sbin/sysctl -w net.ipv4.ip_forward=1


  在server1和sever2上分别创建ip-up和ip-down脚本来添加和删除网络路由。脚本内容如下:

  

#!/bin/sh
# /etc/ppp/ip-up
# Add route for REMOTE_NETWORK
#
REMOTE_IP="${5}"
REMOTE_NETWORK="${6}"
if [ ! "${REMOTE_NETWORK}" = "" ]; then
  /sbin/route add -net ${REMOTE_NETWORK} ${REMOTE_IP}
fi
#!/bin/sh
# /etc/ppp/ip-down
# Delete route for REMOTE_NETWORK
#
REMOTE_IP="${5}"
REMOTE_NETWORK="${6}"
if [ ! "${REMOTE_NETWORK}" = "" ]; then
  /sbin/route delete -net ${REMOTE_NETWORK} ${REMOTE_IP}
fi


  最后,必须在两个局域网络的默认网关上添加正确的路由,也就是将访问VPN对方网络的路由指向VPN服务器。

  在网关192.168.3.1上的/etc/rc.d/rc.local添加:

  

/sbin/route add -net 192.168.5.0 netmask 255.255.255.0 gw 192.168.3.14


  在网关192.168.5.1上的/etc/rc.d/rc.local添加:

/sbin/route add -net 192.168.3.0 netmask 255.255.255.0 gw 192.168.5.18


    如上建立VPN连接以后,用户可以分别在两个局域网络中任意连接对端网络的任何机器。

  相关链接

  VPN(Virtual Private Networks):是一种专用的虚拟网络,允许用户从私人网络(一般个人住处)通过公共网络(一般Internet)安全地远程访问企业资源。VPN技术利用“加密”技术和“隧道”技术来确保传输数据的安全性。

  隧道技术:是一种通过使用互联网络的基础设施在网络之间传递数据的方式。使用隧道传递的数据可以是不同协议的数据包。隧道协议将这些不同协议的数据包重新封装在新的包头中发送。新的包头提供路由信息,从而使封装的负载数据能在隧道的两个端点之间通过公共互联网络进行传递。被封装的数据包在公共互联网络上传递时所经过的逻辑路径称为“隧道”。一旦到达网络终点,数据将被解包并转发到最终目的地。隧道技术是指包括数据封装、传输和解包在内的全过程。

  SSH(Secure Shell Protocol):一种基于安全会话目的的应用程序。SSH支持身份认证和数据加密,对所有传输的数据进行加密处理。同时,可以对传输数据进行压缩处理,以加快数据传输速度。SSH既可以代替Telnet作为安全的远程登录方式,又可以为FTP、POP等提供一个安全的“隧道”。OpenSSH是 SSH的替代软件包,是免费的
分享到:
评论

相关推荐

    SSH-Account Creator-开源

    SSH(Secure Shell)是一种网络协议,用于在不安全的网络上提供安全的远程登录和其他服务。SSH-Account Creator 是一个开源项目,它提供了一个Perl脚本(account.pl),旨在简化在Linux、FreeBSD和SunOS操作系统上...

    2010年广东计算机组网大赛考点

    6. **NFS服务器**:提供基于UNIX/Linux系统的文件共享。 7. **DNS服务器**:Linux下的域名解析服务。 8. **动态DHCP服务器**:同Windows,但使用不同的软件如Dnsmasq或isc-dhcp-server。 9. **动态网站**:通过...

    windows导出自定义镜像工具2

    然后,`ssh.exe -p22222 root@vpn.cinghoo.com`通过SSH(Secure Shell)协议连接到远程服务器`vpn.cinghoo.com`,端口是`22222`,并且使用`root`用户进行操作。这表明镜像文件会被发送到这个远程服务器上。 最后,`...

    远程工具

    它提供了加密的网络通信,常用于Linux和Unix系统的管理,以及在服务器上执行命令。 3. **VNC(Virtual Network Computing)**:VNC是一种基于显示协议的远程控制软件,可让用户查看和控制另一台计算机的图形界面。...

    【电液伺服系统】基于结构不变补偿的低阶线性ADRC控制方法复现与性能分析:电液伺服系统高级控制策略设计(复现论文或解答问题,含详细可运行代码及解释)

    内容概要:本文详细介绍了基于结构不变补偿的电液伺服系统低阶线性主动干扰抑制控制(ADRC)方法的实现过程。首先定义了电液伺服系统的基本参数,并实现了结构不变补偿(SIC)函数,通过补偿非线性项和干扰,将原始系统转化为一阶积分链结构。接着,设计了低阶线性ADRC控制器,包含扩展状态观测器(ESO)和控制律,用于估计系统状态和总干扰,并实现简单有效的控制。文章还展示了系统仿真与对比实验,对比了低阶ADRC与传统PID控制器的性能,证明了ADRC在处理系统非线性和外部干扰方面的优越性。此外,文章深入分析了参数调整与稳定性,提出了频域稳定性分析和b0参数调整方法,确保系统在参数不确定性下的鲁棒稳定性。最后,文章通过综合实验验证了该方法的有效性,并提供了参数敏感性分析和工程实用性指导。 适合人群:具备一定自动化控制基础,特别是对电液伺服系统和主动干扰抑制控制感兴趣的科研人员和工程师。 使用场景及目标:①理解电液伺服系统的建模与控制方法;②掌握低阶线性ADRC的设计原理和实现步骤;③学习如何通过结构不变补偿简化复杂系统的控制设计;④进行系统仿真与实验验证,评估不同控制方法的性能;⑤掌握参数调整与稳定性分析技巧,确保控制系统在实际应用中的可靠性和鲁棒性。 阅读建议:本文内容详尽,涉及多个控制理论和技术细节。读者应首先理解电液伺服系统的基本原理和ADRC的核心思想,然后逐步深入学习SIC补偿、ESO设计、控制律实现等内容。同时,结合提供的代码示例进行实践操作,通过调整参数和运行仿真,加深对理论的理解。对于希望进一步探索的读者,可以关注文中提到的高级话题,如频域稳定性分析、参数敏感性分析等,以提升对系统的全面掌控能力。

    蓝桥杯-嵌入式设计与开发.zip

    蓝桥杯嵌入式

    PCB_PCB_2021-01-22_16-58-07_2025-03-02.json

    PCB_PCB_2021-01-22_16-58-07_2025-03-02.json

    Android毕设实战项目基于Android的运动管理系统.zip

    【项目资源】: 适用于从基础到高级的各种项目,特别是在性能要求较高的场景中,比如操作系统开发、嵌入式编程和底层系统编程。如果您是初学者,可以从简单的控制台程序开始练习;如果是进阶开发者,可以尝试涉及硬件或网络的项目。 【项目质量】: 所有源码都经过严格测试,可以直接运行。 功能在确认正常工作后才上传。 【适用人群】: 适用于希望学习不同技术领域的小白或进阶学习者。 可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】: 项目具有较高的学习借鉴价值,也可直接拿来修改复刻。 对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】: 有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 鼓励下载和使用,并欢迎大家互相学习,共同进步。 # 注意 1. 本资源仅用于开源学习和技术交流。不可商用等,一切后果由使用者承担。 2. 部分字体以及插图等来自网络,若是侵权请联系删除。

    【计算机编程】汇编语言:计算机底层编程的基石与应用领域综述

    内容概要:汇编语言是一种低级编程语言,它作为计算机硬件与高级语言间的桥梁,使用助记符表示机器指令。起源于20世纪40年代末至50年代初,目的是替代难以理解的机器语言。汇编语言的特点在于高效性和灵活性,可直接与硬件交互,充分利用硬件资源。它广泛应用于操作系统开发(如中断处理、内存管理)、嵌入式系统(如实时控制系统)以及对安全性和可靠性要求极高的软件开发中。学习汇编语言有助于深入了解计算机工作原理,提升程序性能优化、复杂问题调试及高性能软件开发的能力,培养逻辑思维和关注细节的习惯。; 适合人群:对计算机底层原理感兴趣的程序员、计算机科学专业学生或希望深入理解计算机硬件与软件交互机制的人士。; 使用场景及目标:①理解计算机底层工作原理;②提高程序性能优化能力;③增强复杂问题调试技巧;④开发高性能、高可靠性的软件。; 其他说明:尽管现代编程更多使用高级语言,但汇编语言的学习价值依然很高,特别是在涉及硬件交互和性能优化方面。建议学习时结合实际项目进行练习,以加深理解。

    毕设单片机实战项目机智云智能插座项目固件源码,基于ESP8266平台.zip

    【项目资源】: 单片机项目适用于从基础到高级的各种项目,特别是在性能要求较高的场景中,比如操作系统开发、嵌入式编程和底层系统编程。如果您是初学者,可以从简单的控制台程序开始练习;如果是进阶开发者,可以尝试涉及硬件或网络的项目。 【项目质量】: 所有源码都经过严格测试,可以直接运行。 功能在确认正常工作后才上传。 【适用人群】: 适用于希望学习不同技术领域的小白或进阶学习者。 可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】: 项目具有较高的学习借鉴价值,也可直接拿来修改复刻。 对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】: 有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 鼓励下载和使用,并欢迎大家互相学习,共同进步。 # 注意 1. 本资源仅用于开源学习和技术交流。不可商用等,一切后果由使用者承担。 2. 部分字体以及插图等来自网络,若是侵权请联系删除。

    PHP面向对象编程与Oracle实战

    本书名为《Web Programming for Business: PHP Object-Oriented Programming with Oracle》,由David Paper撰写,主要面向希望在商业环境中解决数据和技术问题的学生。本书采用Oracle作为后端数据库,内容版本中立,即使PHP和Oracle发生变更,书中代码依然有效。书中代码示例清晰,注重解决方案,并详细解释了如何利用XML、RSS和AJAX等技术在商业应用中。章节内容涵盖了数据库功能、安全编程以及数据转换编程。此外,书中还提供了PowerPoint幻灯片、应用考试题目和示例代码的源文件,旨在通过实例教学帮助读者掌握PHP面向对象编程。大卫·佩珀教授拥有德州仪器和IBM等大公司的实际工作经验,目前在美国犹他州立大学教授计算机科学和商业专业。

    车辆控制Simulink电动车转弯制动ABS与DYC联合控制系统设计:7自由度模型及滑模控制优化使用Simulink

    内容概要:本文详细解析了一个用于电动汽车转弯制动时ABS(防抱死系统)与DYC(横摆力矩控制)协同工作的Simulink模型。模型采用7自由度设计,涵盖纵向、横向、横摆运动及四轮旋转自由度,并引入轮胎魔术公式来精确模拟轮胎力特性。文章重点介绍了ABS系统中的滑移率观测与PID控制策略,以及DYC系统的滑模控制设计,特别是两者之间的协同控制逻辑。通过双移线工况测试验证,该模型能够显著提高车辆稳定性,将横摆角控制在3度以内,并缩短制动距离1.2米。文中还提供了关于模型优化、参数调试的具体建议,以及针对特定工况的仿真技巧。 适合人群:从事车辆控制系统开发的工程师、研究生及对汽车主动安全技术感兴趣的科研人员。 使用场景及目标:①研究ABS与DYC在电动汽车中的协同控制机制;②探索不同路面条件下车辆动态性能优化;③为ESP或TCS系统开发提供参考模型;④比较滑模控制与LQR控制在车辆控制中的应用效果。 阅读建议:建议读者重点关注7自由度模型的设计思路、轮胎魔术公式的实现方式、滑模控制参数调试过程以及ABS和DYC协同控制策略。由于模型涉及较多数学公式和Simulink实现细节,建议结合相关文献深入理解,并通过实际仿真加深认识。

    (源码)基于LVGL图形库的PC模拟器.zip

    # 基于LVGL图形库的PC模拟器 ## 项目简介 本项目是基于LVGL图形库的PC模拟器。LVGL是为嵌入式系统设计的开源图形库,用于创建嵌入式系统的图形用户界面。该项目将LVGL移植到PC上,让开发者无需嵌入式硬件,就能在PC上进行LVGL应用的开发、调试和测试,节约成本且能提升开发效率。 ## 项目的主要特性和功能 1. 跨平台支持可在Windows、Linux和OSX等操作系统上运行。 2. 图形用户界面模拟借助LVGL图形库的各种GUI组件和工具进行模拟。 3. 模拟输入设备能模拟鼠标和键盘的输入操作。 4. 灵活调试通过PC模拟器开发和调试应用程序,便于查找和修复错误。 5. Docker支持便于在Docker容器中运行和测试项目。 ## 安装使用步骤 假设用户已经下载了本项目的源码文件 ### 安装依赖

    毕设单片机实战项目基于ESP8266的家庭版简易开关.zip

    【项目资源】: 单片机项目适用于从基础到高级的各种项目,特别是在性能要求较高的场景中,比如操作系统开发、嵌入式编程和底层系统编程。如果您是初学者,可以从简单的控制台程序开始练习;如果是进阶开发者,可以尝试涉及硬件或网络的项目。 【项目质量】: 所有源码都经过严格测试,可以直接运行。 功能在确认正常工作后才上传。 【适用人群】: 适用于希望学习不同技术领域的小白或进阶学习者。 可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】: 项目具有较高的学习借鉴价值,也可直接拿来修改复刻。 对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】: 有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 鼓励下载和使用,并欢迎大家互相学习,共同进步。 # 注意 1. 本资源仅用于开源学习和技术交流。不可商用等,一切后果由使用者承担。 2. 部分字体以及插图等来自网络,若是侵权请联系删除。

    Android毕设实战项目基于Android的基金投资分析系统.zip

    【项目资源】: 适用于从基础到高级的各种项目,特别是在性能要求较高的场景中,比如操作系统开发、嵌入式编程和底层系统编程。如果您是初学者,可以从简单的控制台程序开始练习;如果是进阶开发者,可以尝试涉及硬件或网络的项目。 【项目质量】: 所有源码都经过严格测试,可以直接运行。 功能在确认正常工作后才上传。 【适用人群】: 适用于希望学习不同技术领域的小白或进阶学习者。 可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】: 项目具有较高的学习借鉴价值,也可直接拿来修改复刻。 对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】: 有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 鼓励下载和使用,并欢迎大家互相学习,共同进步。 # 注意 1. 本资源仅用于开源学习和技术交流。不可商用等,一切后果由使用者承担。 2. 部分字体以及插图等来自网络,若是侵权请联系删除。

    【Python符号计算】SymPy库简介、安装与核心功能详解:涵盖符号运算、微积分、线性代数及应用实例

    内容概要:本文介绍了SymPy,一个用于符号数学的Python库。SymPy起源于2007年,由Ondřej Čertík和Aaron Meurer发起,现已发展成一个活跃的开源社区项目。SymPy的核心功能包括符号计算、数学表达式的解析与简化、微积分、线性代数、物理学和工程学应用、可视化、代码生成等。它支持符号变量的创建和基本代数运算,能求解方程、执行符号积分与微分、计算极限与级数、进行矩阵操作等。此外,SymPy在物理问题(如量子力学中的谐振子问题和经典力学中的运动方程)和数学问题(如函数图形和矩阵变换的可视化)的实际应用中表现出色。安装SymPy可通过pip完成,安装后可通过导入库来验证安装是否成功。SymPy与NumPy的区别在于前者专注于符号数学,后者侧重于数值计算。调试SymPy代码时,可以使用print语句、pprint函数、simplify函数以及断点和调试器等工具。 适合人群:对符号数学感兴趣的程序员、研究人员、教师和学生,尤其是那些希望在Python环境中进行数学研究和教育的人群。 使用场景及目标:①用于符号数学计算,如代数运算、微积分、解方程等;②在物理学和工程学中解析和求解微分方程;③结合Matplotlib等库进行数学表达式的可视化;④将符号表达式转换为其他编程语言的代码,适用于高性能计算和嵌入式系统。 阅读建议:由于SymPy涵盖了广泛的数学功能,建议读者从基础功能入手,逐步深入到高级应用。同时,结合实际案例和可视化工具,以更好地理解和掌握SymPy的强大功能。在学习过程中,可以利用提供的调试工具确保代码的正确性。

    chrome-win.zip

    安装包

    (源码)基于Spring Boot框架的ABrowse基因组浏览器.zip

    # 基于Spring Boot框架的ABrowse基因组浏览器 ## 项目简介 ABrowse是一款轻量级的通用基因组浏览器框架,目标是助力生物学家搭建便捷易用的基因组浏览器。其可视化引擎在浏览器端运行,能为用户带来出色的交互体验。该框架支持GTF、BedGraph、SAM等数据格式以及自定义的存储转录剪接位点的数据格式,数据可通过其提供的接口导入本地mongoDB,开发者还能基于API扩展对更多数据格式的支持。此外,ABrowse支持为同一种数据格式提供多种可视化形式,并且可以借助JavaScript API进一步添加更多可视化方法。软件采用Browser Server架构,后端运用Spring Boot框架,前端由HTML5 + JavaScript实现。 ## 项目的主要特性和功能 1. 多数据格式支持支持GTF、BedGraph、SAM等常见格式以及自定义的转录剪接位点数据格式。

    解码 -getitem- 和 -len- - 自定义序列的钥匙

    解码 -getitem- 和 -len- - 自定义序列的钥匙

Global site tag (gtag.js) - Google Analytics