返回顶部
首页 > 资讯 > 后端开发 > Python >利用Algo在DigitalOcean
  • 431
分享到

利用Algo在DigitalOcean

AlgoDigitalOcean 2023-01-31 08:01:14 431人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

为什么要利用海外的VPS或服务器来搭建自己的VPN服务器呢?首先是为了安全,其次也是为了稳定。 edu用户可以去GitHub Student Developer Pack领取DigitalOcean的优惠券,价值50美元,需要拥有ed

为什么要利用海外的VPS或服务器来搭建自己的VPN服务器呢?首先是为了安全,其次也是为了稳定。

  1. edu用户可以去GitHub Student Developer Pack领取DigitalOcean的优惠券,价值50美元,需要拥有edu邮箱,这样5美元的月租相当于免费使用10个月。
  2. 注册DigitalOcean账户,这里非常欢迎通过我的邀请链接来注册,这样在前2个月你可以获得100美元的使用额度,具体优惠政策可以点进去看。
  3. 对于首次注册DigitalOcean的用户,需要添加支付方式,具体有信用卡和PayPal两种方式,这里笔者在某宝上买了一张充有5美元的虚拟信用卡填了进去。登陆DigitalOcean后进入Accout-Billing,下拉可以看到Promo code,输入在GitHub Student Developer Pack中得到的优惠码,就会免费获得50美元。
  4. 创建Project,并选择一款Droplet,我选择的是最便宜的那款,月租5美元。操作系统选择自己需要的即可,我选择的是ubuntu 18.10 x64。服务器所在地据说北美几个点速度都不错。
  5. 现在你就拥有一台属于自己的VPS了,有没有感觉世界充满了无限可能 ^_^ 在Droplets中通过Droplet的Access console就可以打开服务器的终端窗口,首次登陆需要修改root密码。

AlGo是一个开源的自托管的个人VPN服务器项目,旨在简化部署流程,并提高安全性。

Features

  • 仅支持具有强加密的IKEv2:ES-GCM,SHA2和P-256
  • 生成Apple配置文件以自动配置iOSMacOS设备
  • 包含用于添加和删除用户的辅助脚本
  • 使用本地DNS解析程序过滤广告(可选)
  • 为隧道流量设置有限的ssh用户(可选)
  • 基于当前版本的Ubuntu和strongSwan
  • 可以安装到DigitalOcean,Amazon EC2,Microsoft Azure,Google Compute Engine或者你自己的服务器上

Anti-features

  • 不支持传统密码套件或协议,如L2TP,IKEv1或RSA
  • 不安装Tor,OpenVPN或其它有风险的服务器
  • 不依赖于TLS的安全性
  • 在大多数平台上不需要客户端软件
  • 不提供匿名或审查避免
  • 不保护免受FSB,MSS,DGSE或FSM侵害

部署Algo Server

  1. 打开服务器的console,从GitHub上下载Algo到自己喜欢的位置。

    git clone https://github.com/trailofbits/algo.git
  2. 安装Algo的依赖程序,Algo使用python2而不是python3作为Python程序的解释器,cd进入到algo目录,并运行:

    $ sudo apt-get update && sudo apt-get install \
        build-essential \
        libssl-dev \
        libffi-dev \
        python-dev \
        python-pip \
        python-setuptools \
        python-virtualenv -y
  3. 安装Algo其余的依赖程序,使用与上一步相同的终端窗口,并运行:

    $ python -m virtualenv --python=`which python2` env &&
        source env/bin/activate &&
        python -m pip install -U pip virtualenv &&
        python -m pip install -r requirements.txt
  4. 利用vim或其它文本编辑器打开algo目录下的config.cfg,在users列表中添加需要使用VPN服务的用户名,每个用户名只能用于一台客户机。
  5. 回到终端窗口,在algo目录下运行./algo,按照提示开始部署Algo服务器,注意这里有一些可选功能,根据需要自行改变默认设置。服务器部署完成后,你将看到下列信息,注意一定要记下p12(用户证书)密码,这个密码只会在这里显示一次。

    "\"#----------------------------------------------------------------------#\"",
    "\"#                          Congratulations!                            #\"",
    "\"#                     Your Algo server is running.                     #\"",
    "\"#    Config files and certificates are in the ./configs/ directory.    #\"",
    "\"#              Go to Https://whoer.net/ after connecting               #\"",
    "\"#        and ensure that all your traffic passes through the VPN.      #\"",
    "\"#                    Local DNS resolver 172.16.0.1                     #\"",
    "\"#                The p12 and SSH keys passWord is XXXXXXXX             #\"",
    "\"#----------------------------------------------------------------------#\"",

添加删除用户

如果以后想增添或删除使用VPN服务的设备,怎么办呢?这里Algo提供了便捷的修改方法。

  1. 首先更新config.cfg中的users列表,添加新用户名,或者删除旧用户名。
  2. 开启终端,cd进入algo目录,激活虚拟环境

    source env/bin/activate
  3. 运行命令

    ./algo update-users

全部完成后,Algo VPN服务器将仅支持config.cfg文件中所包含的用户使用

部署VPN客户机

这里只介绍Win10系统的部署方法,其它操作系统请参考Algo官方的README文档。

  1. 在Win10系统上,利用WinSCP从DigitalOcean服务器上下载CA证书(cacert.pem)和用户证书(USER.p12),这两个证书文件都在云服务器的algo/configs/X.X.X.X/目录下,其中X.X.X.X是VPN服务器的IP地址。
  2. 在Win10系统中,以管理员方式打开Powershellcd到证书文件所在目录。
  3. 修改PowerShell执行策略

    Set-ExecutionPolicy Unrestricted -Scope CurrentUser
  4. 将下列代码保存成ps1文件,注意将VpnServerAddress字段修改成VPN服务器的IP地址,将UserP12Path和CaCertPath字段修改成证书文件所在的路径。

    $VpnServerAddress = "1.2.3.4"
    $UserP12Path = "$Home\Downloads\USER.p12"
    $CaCertPath = "$Home\Downloads\cacert.pem"
    $VpnName = "Algo VPN $VpnServerAddress IKEv2"
    $p12Pass = Read-Host -AsSecureString -Prompt "User p12 password"
    
    Import-PfxCertificate -FilePath $UserP12Path -CertStoreLocation Cert:\LocalMachine\My -Password $p12Pass
    Import-Certificate -FilePath $CaCertPath -CertStoreLocation Cert:\LocalMachine\Root
    
    $addVpnParams = @{
        Name = $VpnName
        ServerAddress = $VpnServerAddress
        TunnelType = "IKEv2"
        AuthenticationMethod = "MachineCertificate"
        EncryptionLevel = "Required"
    }
    Add-VpnConnection @addVpnParams
    
    $setVpnParams = @{
        ConnectionName = $VpnName
        AuthenticationTransfORMConstants = "GCMAES256"
        CipherTransformConstants = "GCMAES256"
        EncryptionMethod = "AES256"
        IntegrityCheckMethod = "SHA384"
        DHGroup = "ECP384"
        PfsGroup = "ECP384"
        Force = $true
    }
    Set-VpnConnectionIPsecConfiguration @setVpnParams
  5. 在PowerShell中执行ps1文件,中间会用到之前记下的p12(用户证书)密码。
  6. 部署完成后,记得将PowerShell的执行策略改回来

    Set-ExecutionPolicy Restricted -Scope CurrentUser
  7. 现在,在win10系统界面右下角的网络连接中,你会看到一个叫做Algo VPN X.X.X.X IKEv2的连接,点击连接你就打开新世界的大门了。

Thomas Xu. 浅谈vpn、vps、Proxy以及shadowsocks之间的联系和区别
Patordia. 详细的digitalocean教程
mrpnkt. Setup AlgoVPN in windows 10
lucky_zhang. Windows和linux(ubuntu)互传文件简便快捷的方法

--结束END--

本文标题: 利用Algo在DigitalOcean

本文链接: https://lsjlt.com/news/192526.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 利用Algo在DigitalOcean
    为什么要利用海外的VPS或服务器来搭建自己的VPN服务器呢?首先是为了安全,其次也是为了稳定。 edu用户可以去GitHub Student Developer Pack领取DigitalOcean的优惠券,价值50美元,需要拥有ed...
    99+
    2023-01-31
    Algo DigitalOcean
  • 在DigitalOcean的服务器上部署flaskblog应用
    在DigitalOcean上部署了flaskblog,项目虽小,部署中也学到了很多东西。 操作系统选择的是Ubuntu14.04,原因就是平时自己主要使用这个版本,顺手而已,所以你自己可以根据需要选择合适...
    99+
    2022-06-04
    器上 DigitalOcean flaskblog
  • 如何在DigitalOcean的服务器上安装AMH管理面板
    这篇文章主要介绍“如何在DigitalOcean的服务器上安装AMH管理面板”,在日常操作中,相信很多人在如何在DigitalOcean的服务器上安装AMH管理面板问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答...
    99+
    2023-06-10
  • 如何正确使用主机商DigitalOcean和ConoHa服务器
    这篇文章主要介绍“如何正确使用主机商DigitalOcean和ConoHa服务器”,在日常操作中,相信很多人在如何正确使用主机商DigitalOcean和ConoHa服务器问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对...
    99+
    2023-06-10
  • 怎么在Android中利用canvas绘图
    今天就跟大家聊聊有关怎么在Android中利用canvas绘图,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。MainActivity的代码如下:package exampl...
    99+
    2023-05-30
    android canvas
  • 怎么在html5中利用Canvas绘图
    怎么在html5中利用Canvas绘图?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、什么是CanvasCanvas 是H5的一部分,允许脚本语言动态渲染图像。Canva...
    99+
    2023-06-09
  • 在Fedora中如何利用ffsend使用Firefox Send
    这篇文章将为大家详细讲解有关在Fedora中如何利用ffsend使用Firefox Send,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。什么是 Firefox Send 和 ffsend?Firefox...
    99+
    2023-06-16
  • 利用java如何在高并发使用volatile
    利用java如何在高并发使用volatile?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。java 高并发中volatile的实现原理摘要: 在多线程并发编程中synchr...
    99+
    2023-05-31
    java 高并发 volatile
  • 怎么在Mysql中利用join优化sql
    怎么在Mysql中利用join优化sql?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。0. 准备相关表来进行接下来的测试user1表,取经...
    99+
    2024-04-02
  • 在 Python 中利用Pool 进行多处理
    目录为什么要引入线程池练习为什么要引入线程池 如果在程序中经常要用到线程,频繁的创建和销毁线程会浪费很多硬件资源,所以需要把线程和任务分离。线程可以反复利用,省去了重复创建的麻烦。在...
    99+
    2024-04-02
  • JavaWeb Listener 利用Session统计在线人数
    目录一.监听器Listener1.1 Listener的作用1.2 小demo之统计在线人数1.3 统计结果错误原因分析一.监听器Listener 1.1 Listener的作用 L...
    99+
    2024-04-02
  • 如何利用java在IE中打开Excel
    本篇内容主要讲解“如何利用java在IE中打开Excel”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何利用java在IE中打开Excel”吧!java 代码:publicclass Test...
    99+
    2023-06-03
  • 怎么在Android应用中利用ViewHolder优化Adapter
    怎么在Android应用中利用ViewHolder优化Adapter?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。具体方法如下:public class MarkerItemA...
    99+
    2023-05-31
    adapter viewholder android
  • 在java中怎么利用jna调用c#中dll
    这篇文章给大家介绍在java中怎么利用jna调用c#中dll,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。JNA(Java Native Access )提供一组Java工具类用于在运行期动态访问系统本地库(nativ...
    99+
    2023-05-31
    java jna
  • 怎么在linux中利用shell循环日期
    怎么在linux中利用shell循环日期?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。#!/usr/bin/env bashstart_date=&q...
    99+
    2023-06-09
  • 怎么在html5中利用Canvas旋转图片
    这篇文章给大家介绍怎么在html5中利用Canvas旋转图片,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。移动canvas原点var img = document.getElementBy...
    99+
    2023-06-09
  • 怎么在matplotlib中利用subplot添加子图
    这篇文章给大家介绍怎么在matplotlib中利用subplot添加子图,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。概述subplot()函数向当前图像(figure)添加一个子图(Axes),并将该子图设为当前子图...
    99+
    2023-06-14
  • 怎么在JavaScript中利用map创建数组
    这篇文章将为大家详细讲解有关怎么在JavaScript中利用map创建数组,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。JavaScript是什么JavaScript是一种直译式的脚本语言,...
    99+
    2023-06-14
  • 怎么在python中利用jinja2实现渲染
    这期内容当中小编将会给大家带来有关怎么在python中利用jinja2实现渲染,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Python的优点有哪些1、简单易用,与C/C++、Java、C# 等传统语言相...
    99+
    2023-06-14
  • 怎么在python中利用traceback输出异常
    这篇文章给大家介绍怎么在python中利用traceback输出异常,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。python的数据类型有哪些python的数据类型:1. 数字类型,包括int(整型)、long(长整型...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作