Skip to content

nelvko/clash-for-linux-install

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Linux 一键安装 Clash

因为有在服务器上使用代理的需求,试过许多开源脚本,总是遇到各种问题。于是自己动手,丰衣足食:对 Clash 的安装过程及功能进行了友好封装,使用起来优雅、简单、明确。

img

快速开始

环境要求

  • 需要 rootsudo 权限。
  • 具备 bashsystemd 的系统环境。
  • 已适配:CentOS 7.6Debian 12Ubuntu 24.04.1 LTS

一键安装

git clone https://gh-proxy.com/https://github.com/nelvko/clash-for-linux-install.git \
 && cd clash-for-linux-install \
 && sudo bash -c '. install.sh; exec bash'

如遇问题,请在查阅常见问题issue 未果后进行反馈。

  • 上述克隆命令使用了加速前缀,如失效请更换其他可用链接
  • 不懂什么是订阅链接的小白可参考issue#1
  • 没有订阅?click me
  • 验证是否连通外网:wget www.google.com

命令一览

执行 clash 列出开箱即用的快捷命令。

$ clash
Usage:                                    
    clashon                开启代理       
    clashoff               关闭代理       
    clashui                面板地址       
    clashtun [on|off]      Tun模式        
    clashsecret [secret]   查看/设置密钥  
    clashmixin [-e|-r]     Mixin配置      
    clashupdate [auto|log] 更新订阅

基础使用

$ clashoff
😼 已关闭代理环境

$ clashon
😼 已开启代理环境

$ clashui
😼 Web 面板地址...

原理:

  • 使用 systemctl 控制 clash 启停,并调整代理环境变量的值(http_proxy 等)。因为应用程序在发起网络请求时,会通过其指定的代理地址转发流量,不调整会造成:关闭代理后仍转发导致请求失败、开启代理后未设置代理地址导致请求不转发。
  • clashon 等命令封装了上述流程。

定时更新订阅

$ clashupdate [url]
😼 配置更新成功,已重启生效

$ clashupdate auto [url]
😼 定时任务设置成功

$ clashupdate log
✅ 2024-12-13 23:38:56 配置更新成功 ...
  • clashupdate 会记忆上次更新成功的订阅,后续执行无需再指定订阅 url
  • 可通过 crontab -e 修改定时更新频率及订阅链接。
  • 其他更新方式:pr#24

Web 控制台密钥

控制台密钥默认为空,若暴露到公网使用建议更新密钥。

$ clashsecret xxx
😼 密钥更新成功,已重启生效

$ clashsecret
😼 当前密钥:xxx

Tun 模式

$ clashtun
😾 Tun 状态:关闭

$ clashtun on
😼 Tun 模式已开启
  • 作用:实现本机及 Docker 等容器的所有流量路由到 clash 代理、DNS 劫持等。
  • 原理:clash-verge-revclash.wiki

Mixin 配置

$ clashmixin
😼 查看 mixin 配置(less)

$ clashmixin -e
😼 编辑 mixin 配置(vim)

$ clashmixin -r
😼 查看 运行时 配置(less)
  • 作用:用来存储自定义配置,防止更新订阅后覆盖丢失自定义配置内容。
  • 运行时配置是订阅配置和 Mixin 配置的并集。
  • 相同配置项优先级:Mixin 配置 > 订阅配置。

卸载

以下为通用命令,root 用户可直接使用: . uninstall.sh

sudo bash -c '. uninstall.sh; exec bash'

常见问题

配置下载失败或无效

  • 下载失败:脚本使用 wgetcurl 命令进行了多次重试下载,如果还是失败可能是机场限制,请自行粘贴订阅内容到配置文件:issue#1
  • 订阅配置无效:issue#14

bash: clashon: command not found

  • 原因:使用 bash install.sh 执行脚本不会对当前 shell 生效。
  • 解决:当前 shell 执行下 bash 即可。
几种运行方式的区别:
  • bash 命令运行:当前 shell 开启一个子 shell 执行脚本,对环境的修改不会作用到当前 shell,因此不具备 clashon 等命令。

     # 需要有可执行权限
     $ ./install.sh
     
     # 不需要可执行权限,需要读权限
     $ bash ./install.sh
  • shell 内建命令运行:脚本在当前 shell 环境中执行,变量和函数的定义对当前 shell 有效,root 用户推荐这种方式执行脚本。

    # 不需要可执行权限,需要读权限
     $ . install.sh
     $ source uninstall.sh

ping 不通外网

  • ping 命令使用的是第三层中的 ICMP 协议,不依赖 clash 代理的上层 TCP 协议。
  • 执行 clashtun on 后可以 ping 通,但得到的是 fake ip,原理详见:clash.wiki

服务启动失败/未启动

x86、arm架构

resource 目录中的 clash-linux-amd64-2023.08.17.gzyq_linux_amd64 替换为对应架构版本后再执行安装脚本。

引用

Todo

  • 定时更新配置
  • 😼
  • 适配其他发行版
  • 配置更新日志
  • Tun 模式
  • mixin 配置
  • 适配x86、arm架构
  • bug / 需求

Thanks

@鑫哥

特别声明

  1. 编写本项目主要目的为学习和研究 Shell 编程,不得将本项目中任何内容用于违反国家/地区/组织等的法律法规或相关规定的其他用途。
  2. 本项目保留随时对免责声明进行补充或更改的权利,直接或间接使用本项目内容的个人或组织,视为接受本项目的特别声明。

About

😼 优雅地部署基于 Clash 的代理环境

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages