我的编程空间,编程开发者的网络收藏夹
学习永远不晚

利用Algo在DigitalOcean

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

利用Algo在DigitalOcean

为什么要利用海外的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配置文件以自动配置IOS和macOS设备
  • 包含用于添加和删除用户的辅助脚本
  • 使用本地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系统中,以管理员方式打开PowerShell,cd到证书文件所在目录。
  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)互传文件简便快捷的方法

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

利用Algo在DigitalOcean

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

利用Algo在DigitalOcean

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

在DigitalOcean的服务器上部署flaskblog应用

在DigitalOcean上部署了flaskblog,项目虽小,部署中也学到了很多东西。 操作系统选择的是Ubuntu14.04,原因就是平时自己主要使用这个版本,顺手而已,所以你自己可以根据需要选择合适的linux版本。 部署方案:Vi
2022-06-04

怎么在Android中利用canvas绘图

今天就跟大家聊聊有关怎么在Android中利用canvas绘图,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。MainActivity的代码如下:package example.com
2023-05-30

怎么在html5中利用Canvas绘图

怎么在html5中利用Canvas绘图?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、什么是CanvasCanvas 是H5的一部分,允许脚本语言动态渲染图像。Canva
2023-06-09

利用java如何在高并发使用volatile

利用java如何在高并发使用volatile?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。java 高并发中volatile的实现原理摘要: 在多线程并发编程中synchr
2023-05-31

在Fedora中如何利用ffsend使用Firefox Send

这篇文章将为大家详细讲解有关在Fedora中如何利用ffsend使用Firefox Send,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。什么是 Firefox Send 和 ffsend?Firefox
2023-06-16

怎么在Android应用中利用ViewHolder优化Adapter

怎么在Android应用中利用ViewHolder优化Adapter?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。具体方法如下:public class MarkerItemA
2023-05-31

如何利用java在IE中打开Excel

本篇内容主要讲解“如何利用java在IE中打开Excel”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何利用java在IE中打开Excel”吧!java 代码:publicclass Test
2023-06-03

在java中怎么利用jna调用c#中dll

这篇文章给大家介绍在java中怎么利用jna调用c#中dll,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。JNA(Java Native Access )提供一组Java工具类用于在运行期动态访问系统本地库(nativ
2023-05-31

利用Jdbc在对数据库进行连接

利用Jdbc在对数据库进行连接?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Jdbc连接数据库的基本步骤package demo.jdbc;import jav
2023-05-31

如何在Android中利用Viewpager取消滑动

这期内容当中小编将会给大家带来有关如何在Android中利用Viewpager取消滑动,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。前言现在很多app,首页不允许滑动切换(因为页面加载吧),但是又用vie
2023-05-31

怎么在Android中利用Popwindow弹出菜单

这期内容当中小编将会给大家带来有关怎么在Android中利用Popwindow弹出菜单,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1.popWindow就是对话框的一种方式!此文讲解的android中对
2023-05-31

如何在Android中利用View显示分数

这篇文章给大家介绍如何在Android中利用View显示分数,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。所用的知识:(1)自定义View中的 path ,主要用来绘制指示块。(2)属性动画-ValueAnimator
2023-05-31

怎么在Html5中利用cavas绘制国旗

本篇文章给大家分享的是有关怎么在Html5中利用cavas绘制国旗,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。具体代码如下所示:var canvas = document.g
2023-06-09

怎么在html5中利用Canvas旋转图片

这篇文章给大家介绍怎么在html5中利用Canvas旋转图片,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。移动canvas原点var img = document.getElementById(img)var canv
2023-06-09

怎么在php中利用正则替换width

本篇文章为大家展示了怎么在php中利用正则替换width,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。php正则替换img标签width、height、style 重置图片宽高样式pc网站往往指定了
2023-06-15

怎么在python中利用json保存数据

这篇文章将为大家详细讲解有关怎么在python中利用json保存数据,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。python有哪些常用库python常用的库:1.requesuts;2.s
2023-06-14

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录