Linux 重要配置和软件使用记录
TOC
- TOC
- ftp
- Hugo
- Startup
- v2ray
- clash
- mutt 邮件查看器
- python-venv
- git.io 短链生成
- ElasticSearch
- Github CLI
- Caddy
- Let’s Encrypt
- Nginx
- RSSHub
- lux
- locate
- fzf
- ripgrep
- bat
- Vim
- 主机名称
- 登录欢迎信息
- 命令提示符
- 时区更改
- rclone
- pikpakcli
- iotop
- jq
- Linux apt & yum
- yum 镜像
- apt 镜像
- python3
- verysync
- java
- maven
- node
- mysql
- redis
- c/c++
- git
ftp
1apt install vsftpd
2systemctl status vsftpd
Hugo
1wget https://github.com/gohugoio/hugo/releases/download/v0.134.1/hugo_extended_0.134.1_linux-amd64.tar.gz
2tar -zxvf hugo_extended_0.134.1_linux-amd64.tar.gz
Startup
1# crontab -e
2@reboot /root/startup.sh
v2ray
1# https://github.com/v2fly/fhs-install-v2ray
2bash <(curl -L https://raw.githubusercontent.com/v2fly/fhs-install-v2ray/master/install-release.sh)
3# vim /usr/local/etc/v2ray/config.json
clash
1cd $code && mkdir clash && cd clash
2# 跑路了: wget https://github.com/Dreamacro/clash/releases/download/v1.11.8/clash-linux-amd64-v1.11.8.gz
3gzip -d clash-linux-amd64-v1.11.8.gz
4sudo mv clash-linux-amd64-v1.11.8 /usr/bin/clash
5chmod +x /usr/bin/clash
6wget -O config.yaml https://cop.stc-anycast.com/link/egTt2ZFed953e0m6?sub=3&client=clash
7nohup clash -d . >/dev/null 2>&1 &
8# config: clash.razord.top
1# auto start: /etc/systemd/system/clash.service
2[Unit]
3Description=Clash Proxy
4
5[Service]
6WorkingDirectory=/root
7ExecStart=/usr/bin/clash -d /root/Codes/clash >/dev/null 2>&1
8Type=simple
9RemainAfterExit=yes
10
11[Install]
12WantedBy=multi-user.target
1systemctl daemon-reload
2systemctl start clash
3systemctl enable clash
mutt 邮件查看器
1apt install mutt
python-venv
1apt install python3-venv
2# xx/bin/python3 -m venv venv
git.io 短链生成
1curl -i https://git.io -F "url=https://raw.githubusercontent.com/akynazh/v2ray/master/install.sh" -F "code=v2ray.sh"
ElasticSearch
1# 安装 8.12.0 版本
2wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-8.12.0-linux-x86_64.tar.gz
3wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-8.12.0-linux-x86_64.tar.gz.sha512
4shasum -a 512 -c elasticsearch-8.12.0-linux-x86_64.tar.gz.sha512
5tar -xzf elasticsearch-8.12.0-linux-x86_64.tar.gz
6cd elasticsearch-8.12.0/
7# 安装 ik 中文分词器:
8./bin/elasticsearch-plugin install https://github.com/medcl/elasticsearch-analysis-ik/releases/download/v8.12.0/elasticsearch-analysis-ik-8.12.0.zip
9# 开启服务
10./bin/elasticsearch -d
11# 开启密码保护
12vim config/elasticsearch.yml
13xpack.security.enabled: true
14# 生成密码
15./elasticsearch-setup-passwords auto # 自动
16# ./elasticsearch-setup-passwords interactive # 手动
Github CLI
1type -p curl >/dev/null || (sudo apt update && sudo apt install curl -y)
2curl -fsSL https://cli.github.com/packages/githubcli-archive-keyring.gpg | sudo dd of=/usr/share/keyrings/githubcli-archive-keyring.gpg \
3&& sudo chmod go+r /usr/share/keyrings/githubcli-archive-keyring.gpg \
4&& echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/githubcli-archive-keyring.gpg] https://cli.github.com/packages stable main" | sudo tee /etc/apt/sources.list.d/github-cli.list > /dev/null \
5&& sudo apt update \
6&& sudo apt install gh -y
Caddy
1sudo apt install -y debian-keyring debian-archive-keyring apt-transport-https curl
2curl -1sLf 'https://dl.cloudsmith.io/public/caddy/stable/gpg.key' | sudo gpg --dearmor -o /usr/share/keyrings/caddy-stable-archive-keyring.gpg
3curl -1sLf 'https://dl.cloudsmith.io/public/caddy/stable/debian.deb.txt' | sudo tee /etc/apt/sources.list.d/caddy-stable.list
4sudo apt update
5sudo apt install caddy
安装后 caddy 默认启动,占用 80 和 2019 端口,其中 2019 为 admin api 调用地址,通过如下配置关闭该入口:
1# /etc/caddy/Caddyfile
2{
3 admin off
4}
服务配置:
1# /etc/caddy/Caddyfile
2
3t.akynazh.site {
4 # Set this path to your site's directory.
5 # root * /usr/share/caddy
6
7 # Enable the static file server.
8 # file_server
9
10 # Another common task is to set up a reverse proxy:
11 # reverse_proxy localhost:1200
12 # reverse_proxy /api localhost:1200
13
14 # Or serve a PHP site through php-fpm:
15 # php_fastcgi localhost:9000
16
17 # test
18 respond "Hello, caddy!"
19}
Caddy serves public DNS names over HTTPS using certificates from a public ACME CA such as Let’s Encrypt or ZeroSSL.
Caddy keeps all managed certificates renewed and redirects HTTP (default port 80) to HTTPS (default port 443) automatically.
Let’s Encrypt
1# not recommended
2# apt install certbot
3
4# INSTALL
5path_certbot=/usr/local/share/certbot
6python3 -m venv $path_certbot
7$path_certbot/bin/pip install certbot
8ln -s $path_certbot/bin/certbot /usr/local/bin/certbot
9
10# CERT
11certbot certonly --webroot -w /var/www/html -d akynazh.site -d www.akynazh.site
12# systemctl stop nginx # standalone mode need port 80 first
13certbot certonly --standalone -d api.akynazh.site # service
14
15# RENEW
16# renewal, add to crontab:
1730 2 5 * * certbot renew --pre-hook "systemctl stop nginx" --post-hook "systemctl start nginx"
18# 30 2 5 * * certbot renew
Nginx
1apt install nginx
1; vim /etc/nginx/nginx.conf
2worker_processes 2; # cpu * 1~2
3
4events {
5 worker_connections 2048; # default 1024
6}
7
8http {
9 server {
10 listen 81;
11 listen [::]:81;
12
13 root /var/www/rss;
14 index index.html;
15
16 location / {
17 try_files $uri $uri/ =404;
18 # proxy_pass http://127.0.0.1:8000;
19 }
20 }
21}
1systemctl start nginx
2systemctl status nginx
RSSHub
1git clone
2pnpm install
3# vim .env
4# add some k=v
5npm start
6
7# run in bg
8npm install -g pm2
9pm2 start lib/index.js --name rsshub
10pm2 stop rsshub
11
12# doc
13cd website
14pnpm i
15pnpm run start:zh # pnpm run start
lux
1# amd64
2wget https://github.com/iawia002/lux/releases/download/v0.22.0/lux_0.22.0_Linux_x86_64.tar.gz
3tar -zxvf lux_0.22.0_Linux_x86_64.tar.gz
4mv ./lux /usr/local/bin/
5lux -v
locate
1apt install mlocate
2updatedb
3locate "bot.py"
4
5# updatedb 需要手动执行,否则新文件不会被索引到
fzf
1apt install fzf
2fzf --version
3
4ctrl + r -> search command history
5fzf
ripgrep
1apt install ripgrep
2rg --version
3
4rg -i "test"
5rg -ic "test"
6rg -uuu -ic "test"
bat
1# amd64
2wget https://github.com/sharkdp/bat/releases/download/v0.24.0/bat-musl_0.24.0_amd64.deb
3dpkg -i bat-musl_0.24.0_amd64.deb
4bat --version
Vim
1# /etc/vimrc # or: /etc/vim/vimrc
2
3set tabstop=4 # 修改vim中tab长度
4set shiftwidth=4 # 修改vim自动缩进长度
5set noeb vb t_vb= # 禁用vim蜂鸣声
6set number
1#/etc/inputrc
2
3set bell-style none # 禁用bash蜂鸣声
主机名称
1hostnamectl set-hostname xxx
登录欢迎信息
在 /etc/update-motd.d
自行修改基本欢迎信息。
命令提示符
1vim ~/.bashrc
2
3export PS1="[\u => \w]\$ "
1\a 铃声字符
2\d 格式为“日 月 年”的日期
3\e ASCII 转义字符
4\h 本地主机名
5\H 完全合格的限定域主机名
6\j shell 当前管理的作业数
7\1 shell 终端设备名的基本名称
8\n ASCII 换行字符
9\r ASCII 回车
10\s shell 的名称
11\t 格式为“小时:分钟:秒”的24小时制的当前时间
12\T 格式为“小时:分钟:秒”的12小时制的当前时间
13\A 格式为“小时:分钟”的24小时制的当前时间
14@ 格式为 am/pm 的12小时制的当前时间
15\s shell的名字
16\u 当前用户的用户名
17\v bash shell 的版本
18\V bash shell 的发布级别
19\w 当前工作目录
20\W 当前工作目录的基本名称
21! 该命令的 bash shell 历史数
22# 该命令的命令数量
23$ 如果是普通用户,则为美元符号$;如果超级用户(root 用户),则为井号#。
24\nnn 对应于八进制值 nnn 的字符
25\ 斜杠
26[ 控制码序列的开头
27] 控制码序列的结尾
时区更改
系统时区修改
1root@OranMe2474:~# timedatectl list-timezones | grep Shanghai
2Asia/Shanghai
3root@OranMe2474:~# timedatectl set-timezone Asia/Shanghai
4root@OranMe2474:~# timedatectl
5 Local time: Mon 2022-11-28 10:59:39 CST
6 Universal time: Mon 2022-11-28 02:59:39 UTC
7 RTC time: n/a
8 Time zone: Asia/Shanghai (CST, +0800)
9System clock synchronized: yes
10 NTP service: inactive
11 RTC in local TZ: no
Crontab 时区修改
1# /etc/crontab
2
3CRON_TZ=Asia/Shanghai
4TZ=Asia/Shanghai
1systemctl restart cron
rclone
1# pp:Apps -> pikpak-login beta for rclone
2curl https://rclone.org/install.sh | sudo bash
3rclone -v
4rclone version
5## webdav
6## rclone copy local_path webdav:/
7## rclone sync local_path webdav:/local_path
pikpakcli
1wget https://github.com/52funny/pikpakcli/releases/download/v0.15/pikpakcli_0.15_Linux_x86_64.tar.gz
2tar -zxvf pikpakcli_0.15_Linux_x86_64.tar.gz
3mv ./pikpakcli /usr/bin/
4pikpakcli -h
5mkdir -p ~/.config/pikpakcli
6echo "username:" >> ~/.config/pikpakcli/config.yaml
7echo "password:" >> ~/.config/pikpakcli/config.yaml
8vim ~/.config/pikpakcli/config.yaml
iotop
IO top command
1apt install iotop
2## iostat top
jq
1## centos
2## yum install epel-release
3yum install jq
4## ubuntu
5apt install -y jq
Linux apt & yum
1apt update -y
2apt install curl wget vim net-tools git nginx -y
3## apt install openssh*
4
5--------------------------------------------
6
7yum update -y
8yum install curl wget vim net-tools git nginx -y
9yum install openssh*
yum 镜像
1## huawei
2cp -a /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.bak
3wget -O /etc/yum.repos.d/CentOS-Base.repo https://repo.huaweicloud.com/repository/conf/CentOS-7-reg.repo
4
5## aliyun
6## mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.bak
7## wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo
8
9yum clean all
10yum makecache
11yum -y update
apt 镜像
Debian
1deb http://deb.debian.org/debian buster main contrib non-free
2deb http://deb.debian.org/debian buster-updates main contrib non-free
3deb http://deb.debian.org/debian buster-backports main contrib non-free
4deb http://security.debian.org/debian-security/ buster/updates main contrib non-free
Ubuntu
1cp /etc/apt/sources.list /etc/apt/sources.list.bak
2vim /etc/apt/sources.list
3
4lsb_release -c 查看版本代码
5
6如要用于其他版本,把 focal 换成其他版本代号即可: 22.04:jammy;20.04:focal;18.04:bionic;16.04:xenial;14.04:trusty。
7
8deb https://mirrors.ustc.edu.cn/ubuntu/ focal main restricted universe multiverse
9deb https://mirrors.ustc.edu.cn/ubuntu/ focal-security main restricted universe multiverse
10deb https://mirrors.ustc.edu.cn/ubuntu/ focal-updates main restricted universe multiverse
11deb https://mirrors.ustc.edu.cn/ubuntu/ focal-backports main restricted universe multiverse
12
13---------------------------------------------
14
15deb https://mirrors.ustc.edu.cn/ubuntu/ jammy main restricted universe multiverse
16deb https://mirrors.ustc.edu.cn/ubuntu/ jammy-security main restricted universe multiverse
17deb https://mirrors.ustc.edu.cn/ubuntu/ jammy-updates main restricted universe multiverse
18deb https://mirrors.ustc.edu.cn/ubuntu/ jammy-backports main restricted universe multiverse
python3
pip
如果系统已经安装 python3 但未安装 pip:
1apt install python3-pip
安装
1yum update
2yum install wget gcc openssl-devel bzip2-devel libffi-devel -y
3yum groupinstall "Development Tools" -y
4wget https://www.python.org/ftp/python/3.10.2/Python-3.10.2.tgz
5tar -zxvf Python-3.10.2.tgz
6cd Python-3.10.2
7./configure --enable-optimizations
8make altinstall
9ln -sf /usr/local/bin/python3.10 /usr/bin/python3
10ln -sf /usr/local/bin/python3.10 /bin/python3
11ln -sf /usr/local/bin/pip3.10 /usr/bin/pip3
12ln -sf /usr/local/bin/pip3.10 /usr/bin/pip
13
14------------------------------------------------------
15
16apt update
17apt install software-properties-common -y
18add-apt-repository ppa:deadsnakes/ppa && apt update
19apt install python3.10 -y
20ln -sf /usr/bin/python3.10 /usr/bin/python3
21curl https://bootstrap.pypa.io/get-pip.py -o get-pip.py && python3 get-pip.py
22ln -sf /usr/local/bin/pip3.10 /usr/bin/pip
Pip 镜像配置
1pip config set global.index-url http://pypi.douban.com/simple
2pip config set install.trusted-host pypi.douban.com
遇到的问题
“ssl module in Python is not available” in CentOS
CentOS 7 and RHEL 7 ship an unsupported OpenSSL version. CentOS 7’s EPEL repository comes with openssl11 package. The package install files in non-standard locations and uses a custom pkgconf module name openssl11. You can patch Python’s configure script to use the custom build:
1yum install -y epel
2......
3No package epel available.
4yum search epel
5......
6================================ N/S matched: epel ================================
7epel-release.noarch : Extra Packages for Enterprise Linux repository configuration
8yum install epel-release.noarch
9yum install -y openssl11-devel
10cd /path/to/cpython-sources
11sed -i 's/PKG_CONFIG openssl /PKG_CONFIG openssl11 /g' configure
12./configure --enable-optimizations
13make altinstall
No module named ‘distutils.cmd’
1apt install python3-distutils -y
setup
python setup.py egg_info did not run successfully.
1pip install setuptools -U
lzma
ModuleNotFoundError: No module named ‘_lzma’ 解決方法:
1yum install xz-devel
2yum install python-backports-lzma
3pip install backports.lzma
找到 lzma.py
,如日誌提示的 /usr/local/lib/python3.7/lzma.py
,修改 zma.py
文件中的導入部份如下:
修改前:
1from _lzma import *
2from _lzma import _encode_filter_properties, _decode_filter_properties
修改後:
1try:
2 from _lzma import *
3 from _lzma import _encode_filter_properties, _decode_filter_properties
4except ImportError:
5 from backports.lzma import *
6 from backports.lzma import _encode_filter_properties, _decode_filter_properties
verysync
1curl http://www.verysync.com/shell/verysync-linux-installer/go-installer.sh > go-installer.sh
2chmod +x go-installer.sh
3./go-installer.sh
java
安装
1wget https://repo.huaweicloud.com/java/jdk/8u151-b12/jdk-8u151-linux-x64.tar.gz
2tar -zxvf jdk-8u151-linux-x64.tar.gz
3sudo mkdir /usr/local/java
4sudo mv jdk1.8.0_151 /usr/local/java/jdk1.8
环境变量
1## java env
2export JAVA_HOME=/usr/local/java/jdk1.8
3export CLASSPATH=.:$JAVA_HOME/lib:$JAVA_HOME/jre/lib
4export PATH=$PATH:$JAVA_HOME/bin
maven
安装
1maven_version="3.6.3" ## 3.9.4
2wget "https://archive.apache.org/dist/maven/maven-3/$maven_version/binaries/apache-maven-$maven_version-bin.tar.gz"
3sudo mkdir /usr/local/maven
4tar -zxvf apache-maven-$maven_version-bin.tar.gz
5sudo mv apache-maven-$maven_version /usr/local/maven/$maven_version
6
7## 环境变量
8## MAVEN_HOME=/usr/local/maven/{$maven_version}
9## export PATH=$PATH:$MAVEN_HOME/bin
镜像
1sudo vim ~/.m2/settings.xml
1<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0"
2 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
3 xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 https://maven.apache.org/xsd/settings-1.0.0.xsd">
4
5 <mirrors>
6 <mirror>
7 <id>alimaven</id>
8 <name>aliyun maven</name>
9 <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
10 <mirrorOf>central</mirrorOf>
11 </mirror>
12 </mirrors>
13</settings>
node
安装 node /npm
1apt install nodejs npm
(NVM) 安装和更新 node / npm
1## install nvm pkg manager
2export NVM_DIR="$HOME/.nvm" && (
3 git clone https://github.com/nvm-sh/nvm.git "$NVM_DIR"
4 cd "$NVM_DIR"
5 git checkout `git describe --abbrev=0 --tags --match "v[0-9]*" $(git rev-list --tags --max-count=1)`
6) && \. "$NVM_DIR/nvm.sh"
7
8# 添加一下脚本到 .*rc 文件中
9export NVM_DIR="$HOME/.nvm"
10[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" # This loads nvm
11[ -s "$NVM_DIR/bash_completion" ] && \. "$NVM_DIR/bash_completion" # This loads nvm bash_completion
12
13## close and reopen your terminal to start using nvm
14nvm install node ## This will install the latest version of Node.js and npm.
15
16node -v
17npm -v
18
19nvm current
20## list all the available versions of Node.js that you can install
21nvm ls-remote
22
23## Identify the latest version of Node.js and install it using the following command:
24nvm install <version>
25## nvm install 16.8.0
26
27## If you want to set the newly installed version of Node.js as the default version, you can run the following command:
28nvm alias default <version>
安装 yarn
1npm install -g yarn
安装 pnpm
1npm install -g pnpm
镜像
npm 设置为淘宝源:
1npm config set registry http://registry.npm.taobao.org/
npm 设置为默认源:
1npm config set registry https://registry.npmjs.org/
yarn 设置为淘宝源:
1yarn config set registry https://registry.npm.taobao.org
yarn 设置为默认源:
1yarn config set registry https://registry.yarnpkg.com
mysql
安装
1wget https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm
2rpm -Uvh mysql80-community-release-el7-3.noarch.rpm
3rpm --import https://repo.mysql.com/RPM-GPG-KEY-mysql-2022
4yum install mysql-community-server -y
配置root密码
vim /etc/my.cnf
1+ skip-grant-tables
1mysql
2flush privileges;
3alter mysql.user 'root'@'localhost' identified by 'xxxxxx';
vim /etc/my.cnf
1- skip-grant-tables
redis
1yum install epel-release
2yum install -y redis
3
4-------------------------------------
5
6apt install redis-server
7
8-------------------------------------
9
10## 启动 Redis
11redis-server
12## 检查 Redis 是否正在运行
13redis-cli ping
14## 访问Redis
15redis-cli
16## 停止 Redis
17systemctl stop redis-server
c/c++
1yum install gcc -y
2yum install gcc-c++ -y
3yum install gdb -y
git
安装
1yum install git -y
2
3------------------------------------
4
5apt install git -y
配置密钥
将公钥手动部署到github
配置提交人信息
1git config --global user.name "akynazh"
2git config --global user.email "1945561232@qq.com"
http代理
1git config --global http.https://github.com.proxy socks5://127.0.0.1:7891
ssh代理
1## ~/.ssh/config
2
3Host github.com
4 User git
5 Port 22
6 Hostname github.com
7 IdentityFile ~/.ssh/id_rsa
8 ProxyCommand nc -v --proxy-type socks5 --proxy 127.0.0.1:7891 %h %p
9
10Host ssh.github.com
11 User git
12 Port 443
13 Hostname ssh.github.com
14 IdentityFile ~/.ssh/id_rsa
15 ProxyCommand nc -v --proxy-type socks5 --proxy 127.0.0.1:7891 %h %p
unix系统使用nc(netcat)命令,若未安装netcat,需先安装:
1yum install nc
Go
1# apt install golang-go
2
3wget https://go.dev/dl/go1.22.4.linux-amd64.tar.gz
4
5export PATH="$PATH:/usr/local/share/go/bin"
6export GO111MODULE=on
7export GOPROXY=https://goproxy.io,direct
8export GOPATH=$HOME/.go