江湖夜雨十年灯

ubuntu 下的 clash

李二花 / 2020-03-10


关键词:ubuntu, clash

ubuntu 下的 clash

无论是在 mac 还是 windows 下,我们下在 clash 之后,直接安装,然后在 clash 提供的 gui 界面进行设计即可。

但是 ubuntu 下是不直接提供 gui 界面的,他是通过提供 web 界面来展示的,并且相比于 windows 和 mac 可以直接通过界面进行配置文件的设置和加载, linux 版的 web 界面不提供这个功能。

为了更加方便进行设置,记录一下整个配置的流程。

下载

地址: [github 下载地址](https://github.com/Dreamacro/clash)

具体的 linux 版本位置从 github 的 tags 里寻找,找到一个版本合适的 tags, 然后进入这个 tags 记录的 content 里:

从列表中选择你要的平台的,比如 ubuntu 下,就选择 clash-linux-amd64 的即可。

下载到某个具体的位置,一般是 $HOME/下载, 解压之后就得到了我们想要的 clash 的二进制文件。

安装

我们将解压之后得到的二进制文件,放到 /opt/clash 路径下, 并设置一个软连链接到 /usr/local/bin 目录下,这个目录是我的命令目录,一般安装到 /opt 的文件或者其他软件都会设置一个软连接到这里,方便直接调用。

默认 clash 的配置文件是放在 .config/clash 下的,主要有两个文件,分别是 config.yamlCountry.mmdb,前者是 clash 的主要配置文件,后者是国家信息文件。

但是我们一般不喜欢直接使用默认的配置文件的地址,一个是经常会忘记这个配置文件的具体位置,二是也不是很方便管理,因此我们要将其放到我们配置文件的集中管理的地方 /etc 下,我们在 /etc 下建立文件夹 clash/ 用于放置我这两个具体的配置文件,将配置文件迁移到这个位置之后,启动 clash 的命令就要指定对应的配置文件的具体地址或者目录,如下:

# 使用 -d 指定配置文件的目录地址
$ clash -d . # current directory
$ clash -d /etc/clash

# 使用 -f 指定配置文件的地址
$ clash -f ./config.yaml # current directory
$ clash -f /etc/clash/config.yaml

参考地址: clash 的配置文件参数含义

此时,直接运行 clash -d /etc/clash 就可以将 clash 启动了,在讲解提供服务后的端口信息和 web 信息之前,我们先了解下具体的配置文件,方便我们更好的知道接下来怎么做。

配置简介

# Port of HTTP(S) proxy server on the local end
# 提供 http 代理的端口,注意需要配置代理的时候需要用到
port: 7890

# Port of SOCKS5 proxy server on the local end
# 提供 socks5 代理的端口 ,注意配置代理的时候需要用到
socks-port: 7891

# Clash router working mode
# rule: rule-based packet routing
# global: all packets will be forwarded to a single endpoint
# direct: directly forward the packets to the Internet
mode: rule

# Clash by default prints logs to STDOUT
# info / warning / error / debug / silent
# 日至的级别,设置哪个级别,打印出来的就是那个级别以上的日至
log-level: info

# When set to false, resolver won't translate hostnames to IPv6 addresses
ipv6: false

# RESTful web API listening address
# web 界面的地址,这个注意设置的时候的端口号,打开 http://clash.razord.top/#/proxies 时要配置
external-controller: 127.0.0.1:9090

# A relative path to the configuration directory or an absolute path to a
# directory in which you put some static web resource. Clash core will then
# serve it at `http://{{external-controller}}/ui`.
external-ui: folder

# Secret for the RESTful API (optional)
# Authenticate by spedifying HTTP header `Authorization: Bearer ${secret}`
# ALWAYS set a secret if RESTful API is listening on 0.0.0.0
# secret: ""

# Outbound interface name
interface-name: en0

... more

介绍这些配置主要是因为,我们除了将 clash 启动,还需要在系统配置上配置好这些代理,并且打开我们的 web 界面查看服务是否正常了。

配置系统代理界面

按照如下的方式进行系统代理的配置:

配置 clash web 界面

打开浏览器,输入地址 http://clash.razord.top, 此时会弹出一个设置 web 端口号的界面,填入在配置文件里 external-controller 对应的地址即可,然后就可以查看界面上的内容了。

至此,最基础的 clash 的配置已经完成,总结以下就是:

下载, 安装,配置,系统代理,界面设置

启动

为了防止 clash 随着某个 terminal 挂掉,我们设置将 clash 作为开机启动项,并用 systemctl 守护一下。

/etc/systemd/system 下新建文件 clash.service, 得到 /etc/systemd/system/clash.service 文件,然后填入以下配置:

[Unit]
Description=clash daemon

[Service]
Type=simple
User=fupeng
ExecStart=/usr/local/bin/clash -d /etc/clash
Restart=on-failure

[Install]
WantedBy=multi-user.target

保存之后,sudo systemctl daemon-reload 重新加载配置文件。

sudo systemctl start clash.service 启动服务,如果想设置为开机启动,执行 systemctl enable clash.service 即可。

后话

systemd 配置

关于 systemd 的配置文件的简介

[Unit]

Description : 服务的简单描述

Documentation : 服务文档

Before、After:定义启动顺序。Before=xxx.service,代表本服务在xxx.service启动之前启动。After=xxx.service,代表本服务在xxx.service之后启动。

Requires:这个单元启动了,它需要的单元也会被启动;它需要的单元被停止了,这个单元也停止了。

Wants:推荐使用。这个单元启动了,它需要的单元也会被启动;它需要的单元被停止了,对本单元没有影响。

[Service]

Type=simple(默认值):systemd认为该服务将立即启动。服务进程不会fork。如果该服务要启动其他服务,不要使用此类型启动,除非该服务是socket激活型。

Type=forking:systemd认为当该服务进程fork,且父进程退出后服务启动成功。对于常规的守护进程(daemon),除非你确定此启动方式无法满足需求,使用此类型启动即可。使用此启动类型应同时指定 PIDFile=,以便systemd能够跟踪服务的主进程。

Type=oneshot:这一选项适用于只执行一项任务、随后立即退出的服务。可能需要同时设置 RemainAfterExit=yes 使得 systemd 在服务进程退出之后仍然认为服务处于激活状态。

Type=notify:与 Type=simple 相同,但约定服务会在就绪后向 systemd 发送一个信号。这一通知的实现由 libsystemd-daemon.so 提供。

Type=dbus:若以此方式启动,当指定的 BusName 出现在DBus系统总线上时,systemd认为服务就绪。

Type=idle: systemd会等待所有任务(Jobs)处理完成后,才开始执行idle类型的单元。除此之外,其他行为和Type=simple 类似。

PIDFile:pid文件路径

ExecStart:指定启动单元的命令或者脚本,ExecStartPre和ExecStartPost节指定在ExecStart之前或者之后用户自定义执行的脚本。Type=oneshot允许指定多个希望顺序执行的用户自定义命令。

ExecReload:指定单元停止时执行的命令或者脚本。

ExecStop:指定单元停止时执行的命令或者脚本。

PrivateTmp:True表示给服务分配独立的临时空间

Restart:这个选项如果被允许,服务重启的时候进程会退出,会通过systemctl命令执行清除并重启的操作。

RemainAfterExit:如果设置这个选择为真,服务会被认为是在激活状态,即使所以的进程已经退出,默认的值为假,这个选项只有在Type=oneshot时需要被配置。

[Install]

Alias:为单元提供一个空间分离的附加名字。

RequiredBy:单元被允许运行需要的一系列依赖单元,RequiredBy列表从Require获得依赖信息。

WantBy:单元被允许运行需要的弱依赖性单元,Wantby从Want列表获得依赖信息。

Also:指出和单元一起安装或者被协助的单元。

DefaultInstance:实例单元的限制,这个选项指定如果单元被允许运行默认的实例。

systemd 开机启动

systemctl enable clash.service之后,就会在 /etc/systemd/system/multi-user.target.wants/ 目录下新建一个 /usr/lib/systemd/system/clash.service 文件的链接。

Created symlink /etc/systemd/system/multi-user.target.wants/clash.service → /etc/systemd/system/clash.service.