Ubuntu 19.10 配置与优化
转自:https://www.cnblogs.com/leviatan/p/12701974.html
0x00 环境
cpu: intel core i9-9900k
gpu: geforce rtx 2070 super
ram: ddr4 16gbx2
os 1: ubuntu 19.10 eoan
os 2: windows 10 1909
disk 1: samsung ssd 970 evo plus 500gb - guid partition table(/dev/nvme0n1
)
disk 2: st4000vx007-2dt166 - guid partition table(/dev/sda
)
disk 3: samsung ssd 850 evo m.2 250gb - guid partition table(/dev/sdb
)
ubuntu partition 1: 1g - ext4 - /boot/
- 逻辑分区(/dev/sdb1
)
ubuntu partition 2: 2g - swap - swap - 逻辑分区(/dev/sdb2
)
ubuntu partition 3: 40g - ext4 - /home/
- 逻辑分区(/dev/sdb3
)
ubuntu partition 4: 206g - ext4 - /
- 主分区(/dev/sdb4
)
0x01 前言
阅读顺序
强烈建议先仔细阅读一遍本文,了解注意事项及大概流程后,再应用到实际部署中
开发环境
本文中配置的开发环境主要面向 web 开发及运维,主要包括 nodejs, go, nginx, php, mysql, python
由于 c 的开发环境笔者主要依靠 vscode + gcc + gbd,每个人有不同的配置习惯且不同需求的环境相差较大,这里不做详细描述
本机配置
本文所有操作基于 win10 + ubuntu 双系统,先安装 win10,再安装 ubuntu。安装 ubuntu 时使用单块硬盘(disk 3)配置分区,将 ubuntu 引导系统放在 windows boot manager(/dev/nvme0n1p2
),也就是 windows 的 efi 分区中,安装完成后该分区将作为引导分区被挂载到 /boot/efi/
目录
如果不使用双系统
单独安装 ubuntu 或在虚拟机中安装,并不影响本文中大部分操作,唯一需要注意的是不需要在 grub 中调整引导顺序
为什么使用 ubuntu 19.10
在所有 linux 发行/衍生版本中,ubuntu 是唯一适合日常开发使用,环境较为成熟,社区论坛较多,软件支持全面并且符合用户操作习惯的版本
在笔者尝试安装 ubuntu 19.04 的过程中,发现部分硬件打不上驱动,导致了安装后有很多关于底层驱动的操作不适合普通用户,并且 19.10 与 19.04 差距并不大,很多适用于 19.04(disco) 的软件源同样也适用于 19.10(eoan),所以最后选择了 ubuntu 19.10
有哪些用户
文中主要涉及三个用户
-
root
- 根用户,在系统中拥有最高权限
-
user
- 系统用户,笔者使用的用户名是 simonriley ,文中为便于辨认使用 user 代替
-
www-data
- 大部分 web 服务使用的用户,由 nginx 或 php-fpm 自动创建,只有 web 服务需要使用该用户
用户与系统环境变量配置
按照笔者的习惯,为保证 root 与 user 使用相同的环境,/root/
目录下 .bashrc
,.dircolors
和 .condarc
三个配置文件均使用 /home/user/
目录下同名文件的软连接
实际部署中发现 root 用户可能不会从 /etc/profile
读取环境变量配置,所以在 .bashrc
中添加如下配置
source /etc/profile
注意:在
.bashrc
配置中,为保证后续添加的配置不会被覆盖,默认将新增的配置写在该行下面
文件权限配置
使用软件包管理器安装的包,管理器会自动配置权限,但有些包是我们手动下载并配置的,例如 /usr/local/node/
目录,对于这类包,建议在配置完成后使用下面的命令手动将其权限修改为 user
sudo chown user:user -r /usr/local/node/
在终端中使用的用户
终端默认使用的用户是 user ,但实际操作中会遇到很多需要使用 root 权限的命令,在本文中调用该权限的方式为 sudo <command>
注意:在对系统没有足够了解的情况下不建议直接使用 root 用户操作,即使足够了解也请先确认自己知道每一步操作的作用和可能造成的后果。使用 root 用户进行操作所造成的任何损失(包括但不限于文档资料损坏或丢失及硬件损坏)笔者不承担任何责任
如果您认为自己有一定 linux 操作知识,也可以直接使用 sudo -s
切换到 root 用户进行操作,只要保证创建一些需要从桌面启动的文件/文件夹时能够将其权限设置为 user ,或出现权限问题能够通过查看和理解错误输出及时意识到问题所在即可
注意:在对系统没有足够了解的情况下不建议直接使用 root 用户操作,即使足够了解也请先确认自己知道每一步操作的作用和可能造成的后果。使用 root 用户进行操作所造成的任何损失(包括但不限于文档资料损坏或丢失及硬件损坏)笔者不承担任何责任
文中有些文件名为什么和我下载的不一样
文中下载的有些文件名是带有版本号的,例如 software-1.12.1.tar.gz
,这里所有版本号均使用 “x” 代替:software-x.xx.x.tar.gz
配置的应用及重启
文中很多配置在完成后需要重启才会被应用,为减少重启次数,本文将所有重启应用的配置都放在 0x02 步骤中,完成该步骤后只需重启一次
0x02 安装后保证系统能够正常使用
系统使用 rtc 时间
ubuntu 安装完成后会出现系统时间与硬件时间不同步的情况,导致 windows 时间不正确,windows 端无法进行加密相关的验证
timedatectl set-local-rtc 1 --adjust-system-clock
更换国内软件源
软件源分别来自 tuna(清华大学 tuna 协会 创建的 )和 opsx( 创建的 )
编辑 /etc/apt/sources.list
删除原本的源,添加如下
## tuna deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ eoan main restricted universe multiverse deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ eoan main restricted universe multiverse deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ eoan-updates main restricted universe multiverse deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ eoan-updates main restricted universe multiverse deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ eoan-backports main restricted universe multiverse deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ eoan-backports main restricted universe multiverse deb https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ eoan-security main restricted universe multiverse deb-src https://mirrors.tuna.tsinghua.edu.cn/ubuntu/ eoan-security main restricted universe multiverse ## opsx deb http://mirrors.aliyun.com/ubuntu/ eoan main restricted universe multiverse deb-src http://mirrors.aliyun.com/ubuntu/ eoan main restricted universe multiverse deb http://mirrors.aliyun.com/ubuntu/ eoan-security main restricted universe multiverse deb-src http://mirrors.aliyun.com/ubuntu/ eoan-security main restricted universe multiverse deb http://mirrors.aliyun.com/ubuntu/ eoan-updates main restricted universe multiverse deb-src http://mirrors.aliyun.com/ubuntu/ eoan-updates main restricted universe multiverse deb http://mirrors.aliyun.com/ubuntu/ eoan-proposed main restricted universe multiverse deb-src http://mirrors.aliyun.com/ubuntu/ eoan-proposed main restricted universe multiverse deb http://mirrors.aliyun.com/ubuntu/ eoan-backports main restricted universe multiverse deb-src http://mirrors.aliyun.com/ubuntu/ eoan-backports main restricted universe multiverse
更改完成后检查所有软件包的更新并升级
sudo apt update sudo apt upgrade
使 root 与 user 配置同步
将 /home/user/
目录下的配置建立到 /root/
目录的软链接
sudo ln -sf /home/user/.bashrc /root/ sudo ln -sf /home/user/.dircolors /root/
安装常用软件包
sudo apt install curl git htop fcitx-googlepinyin gnome-tweak-tool gnome-shell-extensions chrome-gnome-shell vim hwinfo
软件包 | 用途 |
---|---|
curl | 基于 url 的文件传输/请求模拟 |
git | github 命令行客户端 |
htop | 进程管理 |
fcitx-googlepinyin | google 拼音输入法 |
gnome-tweak-tool | gnome 优化工具 |
gnome-shell-extensions | gnome 扩展管理 |
chrome-gnome-shell | chrome 的 gnome 扩展管理插件 |
vim | 基于命令行的文本编辑器 |
hwinfo | 查看硬件信息 |
安装语言支持并修改输入法
从应用菜单中找到 语言支持 ,打开后会提示 系统中安装的语言支持不完整 ,点击 安装 ,等待安装完成
安装完成后,将键盘输入法系统更改为 fcitx
此时输入法修改并不会立即生效
0x03 优化显示
优化 grub 显示
grub 实际的配置文件是由多个配置自动生成的,所以这里需要修改多个文件
修改 grub 分辨率
grub 默认会使用硬件能够输出的最小分辨率,导致 grub 界面模糊
查看显卡在 grub 中能够输出的分辨率
sudo hwinfo --framebuffer
笔者该命令的输出中,最大分辨率 1920x1080,实际使用中可能会出现更高的分辨率
在 /etc/default/grub
中修改 grub 显示分辨率为刚才查询到的最大分辨率
grub_gfxmode=1920x1080
[可选] 修改 grub 中显示的操作系统顺序
/etc/grub.d/
目录中存放的是 grub 能够引导的操作系统的配置文件,按照 启动顺序_操作系统名
生成实际的启动顺序
这里由于笔者习惯,需要将第一启动项修改为 windows,直接将 30_os-prober
前的数字改到小于 10_linux
即可
注意:该目录下有一些需要在所有操作系统前启动的配置,例如
00_header
和05_debian_theme
,修改的数字要大于这些
为 grub 安装主题
在 grub2-themes - github 下载 release 包
解压后运行 install.sh
,通过参数选择主题及支持的分辨率,具体请参考上面的 github 项目主页
这里安装的是 vimix 主题
sudo ./install.sh --vimix
修改 grub 背景颜色
虽然已经设置了 grub 主题,但实际上它只是在默认的紫色背景上显示了一张图片进行覆盖,当选择操作系统退出 grub 后,有些主板仍然会显示默认的紫色背景
这可能导致启动系统时屏幕出现 黑 -> grub -> 黑 -> 紫 -> 黑 -> os ,影响美观,所以这里将背景修改为黑色
编辑 /usr/share/plymouth/themes/default.grub
文件,将原本的脚本注释并写入新的
#if background_color 79,25,76,0; then if background_color 0,0,0; then
应用以上 grub 更改
上面说过 grub 的配置是由多个文件生成的,系统提供了升级 grub 重新生成配置文件的命令
update-grub
优化终端显示
修改终端配色
这里先修改 /home/user/
目录下的 .bashrc
和 .dircolors
,然后在 /root/
目录下建立软链接,确保能够同步
在 ~/.bashrc
中注释掉如下配置
#if [ "$color_prompt" = yes ]; then # ps1='${debian_chroot:+($debian_chroot)}\[\033[01;32m\]\u@\h\[\033[00m\]:\[\033[01;34m\]\w\[\033[00m\]\$ ' #else # ps1='${debian_chroot:+($debian_chroot)}\u@\h:\w\$ ' #fi #unset color_prompt force_color_prompt # if this is an xterm set the title to user@host:dir #case "$term" in #xterm*|rxvt*) # ps1="\[\e]0;${debian_chroot:+($debian_chroot)}\u@\h: \w\a\]$ps1" # ;; #*) # ;; #esac
并添加如下配置
ps1='${debian_chroot:+($debian_chroot)}\[\033[01;32m\]\u@\h\[\033[00m\]:\[\033[38;5;39m\]\w\[\033[00m\]\$ '
但此时使用 ls 命令显示的文件夹颜色较深,使用下面的命令修改
dircolors -p > ~/.dircolors sed -ie 's/dir 01;34/dir 38;5;39/g' ~/.dircolors
优化 terminal 窗口显示
ctrl + alt + t
打开 terminal 窗口
-
右上角设置
- 配置文件首选项
-
常规
- 关闭 启用菜单快捷键(影响 htop 退出)
-
配置文件
-
未命名
-
文本
-
文本外观
- 终端起始尺寸 140 列 40 行
-
文本外观
-
颜色
-
文本和背景颜色
- 关闭 使用系统主题中的颜色
- 内置方案 -> tango 暗色
- 关闭 使用系统主题的透明度
- 开启 使用透明背景 ,将其调整为约 15%
-
文本和背景颜色
-
滚动
- 关闭 回滚限制到 10000 行
-
文本
-
未命名
0x04 日常使用优化
修改用户 home 目录下文件夹名为英文
由于日常使用终端使用的都是英文,切换到中文目录中比较麻烦,并且中文可能会导致一些问题
注意:该步骤所有命令使用 user 用户操作
通过以下命令修改系统语言
export lang=en_us
更新 gtk 语言
xdg-user-dirs-gtk-update
弹出 update standard folders to current language? 对话框,选择 update names
一下命令将系统语言重新修改为中文
export lang=zh_cn
此时该步骤并未结束,重启后会提示 将标准文件夹更新到当前语言吗? ,先选择 不要再次询问我 ,再点击 保留旧的名称
重启
以上大部分更改都是重启后才被应用,为减少重启次数,本文先完成以上所有配置,至此重启一次即可
注意:此时重启后默认启动项是 windows
0x05 桌面优化
卸载不需要的软件
打开 ubuntu 软件
卸载如下软件包
- aisleriot 纸牌游戏
- amazon
- gnome 扫雷
- gnome 数独
- gnome 麻将牌
- firefox 网络浏览器
或者您习惯使用 firefox 浏览器可以留下它,但强烈推荐您使用 chrome 浏览器
安装 chrome 请参考步骤 0x07
卸载预装扩展
删除 /usr/share/gnome-shell/extensions/
目录下所有扩展(dash to dock 扩展与某个预装扩展会产生冲突导致安装失败)
alt + f2
,输入 r
并回车重载桌面
在 chrome 中安装扩展
在 chrome 中安装 gnome shell integration 扩展
安装完成后访问 gnome extensions
进入扩展页面后开启扩展即可自动安装,在 优化 应用中可以管理扩展
推荐如下扩展
- user themes
- dash to dock
- top icons plus
top icons plus 扩展需要使用包管理器安装
sudo apt install gnome-shell-extension-top-icons-plus
安装 gnome shell 主题
访问 gnome look - gnome shell themes 下载更多,各主题安装方式可能不同,请参考主题页面
推荐 flat-remix 主题
sudo add-apt-repository ppa:daniruiz/flat-remix sudo apt update sudo apt install flat-remix-gnome
安装图标主题
推荐 paper 图标主题
sudo add-apt-repository -u ppa:snwh/ppa
该源中并不包含 ubuntu 19.10(eoan),但 ubuntu 19.04(disco)的主题包也可以应用在 19.10 中,这里手动更改版本
编辑 /etc/apt/sources.list.d/snwh-ubuntu-ppa-eoan.list
将链接后的 eoan 修改为 disco
更新软件包列表并安装图标主题
sudo apt update sudo apt install paper-icon-theme
修改 gnome 桌面设置
打开 gnome tweak tool(优化)
-
外观
-
主题
- 应用程序 -> adwaita-dark
- 图标 -> paper
- shell -> flat-remix-darkest-fullpanel
-
主题
- 开机启动程序 -> 添加 *
配置 dash to dock 扩展
打开 gnome tweak tool(优化)
-
扩展
- 配置 dash to dock
-
位置和大小
-
智能隐藏设置
-
自动隐藏
- 开启 在全屏模式下启用
- 避开窗口 -> 选择 仅最大化窗口
-
自动隐藏
-
智能隐藏设置
-
启动器
- 开启 隔离工作区
-
外观
- customize windows counter indicators -> dashes
-
自定义透明度 -> 固定
- 20%
alt + f2
,输入 r
并回车重载桌面
0x06 开发环境安装及配置
[可选] * 或 *r
下载 * 各组件
如果您有服务商或自建节点,该步骤将帮助您使用 * 或 *r 连接 vmess 及 ssr 节点
该步骤使用 * 举例,*r 相同
在 * - github 下载 release 包
注意:下载
*-linux-amd64-vx.xx.x.gz
格式的包
或在 *r - github 下载 release 包
注意:下载
*r-linux-amd64-vx.xx.x.x.gz
格式的包
解压后重命名为 *
或 *r
并赋予执行权限
mv *-linux-amd64-vx.xx.x * chmod +x *
在 maxmind-geoip - github 下载 country.mmdb
文件,该文件提供基于 ip 的定位
在* github 源码 中下载 * 的 logo,作为桌面图标
在您的服务商处下载 * 或 *r 节点列表,并更名为 config.yaml
将以上四个文件放到 /usr/local/*/
目录中
启动脚本
该脚本实现了以下功能
- 检查正在运行的 * 客户端并关闭
- 为 * 生成运行日志
- 启动新的 * 客户端
- 每次启动时检查日志是否超过 15 份,超出删除
在该文件夹下建立 * 的启动脚本 *_startup.sh
注意:脚本中变量值根据实际情况配置
#!/bin/bash *_app_name="*" *_app_path="/usr/local/*" *_config_path="/usr/local/*" *_log_path="/usr/local/*/log" log_date=$(date +'%y%m%d') check_*_pid=$(ps aux | grep "./$*_app_name -d $*_config_path" | grep -v grep | awk '{print $2}') mkdir -p $*_log_path log_num=$(ls -lr $*_log_path | wc -l) log_num_max=15 if [ -n "$check_*_pid" ]; then for *_pid in $check_*_pid; do kill -9 $*_pid done fi cd $*_app_path && nohup ./$*_app_name -d $*_config_path 2>&1 >>$*_log_path/$*_app_name-$log_date.log & if [ $log_num -gt $log_num_max ]; then for i in $(seq 1 $(($log_num-$log_num_max))); do log_old=$(ls $*_log_path | sort -n | head -1) rm -f $*_log_path/$log_old done fi
为脚本添加执行权限
chmod +x *_startup.sh
* 桌面图标
在 /usr/share/applications/
目录中 创建 * 桌面图标文件 *.desktop
并写入如下配置
注意:配置值根据实际情况填写
[desktop entry] version=1.0 name=* genericname=* comment=* exec=/usr/local/*/*_startup.sh terminal=false icon=/usr/local/*/logo.png type=application categories=network
* 管理界面的桌面图标
在 /usr/share/applications/
目录中 创建 * 管理界面的桌面图标文件 *-panel.desktop
并写入如下配置
注意:配置值根据实际情况填写
注意:该配置是使用 chrome 打开
http://*.razord.top/
,如果使用其他浏览器,将exec
项的值修改为您使用的浏览器打开指定链接的命令即可
[desktop entry] version=1.0 name=* panel genericname=* panel comment=* admin gui exec=/usr/bin/google-chrome-stable http://*.razord.top/ terminal=false icon=/usr/local/*/logo.png type=application categories=network
配置系统和应用代理
* 默认使用 7890 端口进行 http/https 代理,使用 7891 端口进行 socks5 代理
系统设置 -> 网络 -> 网络代理 -> 手动 ,设置为如下值
http 代理 127.0.0.1 7890 https 代理 127.0.0.1 7890 socks 主机 127.0.0.1 7891
此时即可配置应用代理为以上对应的地址和端口实现代理(chrome 默认使用系统的配置)
配置命令行代理
但有些命令行不使用 gnome 中设置的代理,可以通过软件包 proxychains 设置
sudo apt install proxychains
编辑 /etc/proxychains.conf
注释掉最后一行的 socks4 配置,添加 socks5 配置
#socks4 127.0.0.1 9050 socks5 127.0.0.1 7891
使用方法
proxychains <command>
测试
proxychains curl google.com
mysql 8.0
从 下载安装包
注意:该安装包的作用是将 mysql 官方源列表安装到本地,并非直接安装 mysql
点击 download 后在跳转的页面中选择 no thanks, just start my download
下载完成后使用 apt 安装
sudo apt install ./mysql-apt-config_0.8.15-1_all.deb
在弹出的 mysql-apt-config 中选择 ok
安装完成后更新软件包列表并安装 mysql-server 包
注意:建议先使用
apt show mysql-server
查看包信息,确认 apt-source 项为 mysql 官网(repo.mysql.com)
sudo apt update sudo apt install mysql-server
根据提示输入 mysql root 用户的密码
注意:该用户是 mysql 的根用户,与系统 root 用户不同
在 select default authentication plugin 中有以下两个选项,如果想使用新版加强的密码加密插件,可以选择第一个。想使用 5.x 版本的认证方法,选择第二个。他们的区别主要在于对密码强度的要求
use strong password encryption (recommended)
use legacy authentication method (retain mysql 5.x compatibility)
这里建议选择第二个,在实际测试中发现第一项可能导致某些客户端无法登录的问题
anaconda3
anaconda 是一个很方便的 python 包和虚拟环境管理器,详情请参考 anaconda doc
安装 anaconda3
从 tuna 下载 anaconda3-xxxx.xx-linux-x86_64.sh
格式的安装脚本
赋予执行权限并安装
chmod +x anaconda3-xxxx.xx-linux-x86_64.sh ./anaconda3-xxxx.xx-linux-x86_64.sh
安装过程中会询问安装位置,填写为 /usr/local/anaconda3
即可
安装最后一步会询问 do you wish the installer to initialize anaconda3 by running conda init? [yes|no]
建议输入 yes
更换为 tuna 源
换 tuna 源
首先使用 user 用户执行 conda config --set show_channel_urls yes
命令生成配置文件
修改 user 用户 home 目录下的 .condarc
文件为如下
channels: - defaults show_channel_urls: true channel_alias: https://mirrors.tuna.tsinghua.edu.cn/anaconda default_channels: - https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/main - https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/free - https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/r - https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/pro - https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/msys2 custom_channels: conda-forge: https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloud msys2: https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloud bioconda: https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloud menpo: https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloud pytorch: https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloud simpleitk: https://mirrors.tuna.tsinghua.edu.cn/anaconda/cloud
在 root 用户 home 目录下建立软连接
sudo ln -sf /home/user/.condarc /root/
anaconda 默认使用 python 3.7,但实际开发中多使用 python 3.6
清除索引缓存并将当前 conda 环境下 python 版本替换为 3.6
conda clean -i conda install python=3.6
java se 8u241
截至目前(2020年4月12日),oracle 发布的最新 java se 版本为 14,但为了兼容旧项目以及其他应用,这里仍然选择安装配置 java se 8u241
访问 java 官网
点击 java se development kit 8u241 下的 linux x64 compressed archive 右侧链接下载
在弹出的对话框中选中 i reviewed and accept ... ,然后点击 下载
在跳转的页面中登录 oracle 帐号
解压后将其移动到 /usr/local/
目录下
编辑 /etc/profile
文件,增加如下配置
export path=$path:/usr/local/jdk1.8.0_241/bin export java_home=/usr/local/jdk1.8.0_241 export jre_home=/usr/local/jdk1.8.0_241/jre
go
访问 golang 官网
点击 linux 开始下载
解压后移动到 /usr/local/
目录下
在 /etc/profile
中添加以下配置
export path=$path:/usr/local/go/bin export goroot=/usr/local/go export gopath=/usr/local/go/src
nodejs
安装 nodejs
访问 nodejs 官网
点击 长期支持版 开始下载
解压后重命名为 node
并移动到 /usr/local/
目录下
在 /etc/profile
中添加以下配置
export path=$path:/usr/local/node/bin
安装 cnpm
由于 npm 官方源位于国外,这里安装 cnpm,使用淘宝源进行 nodejs 包管理,在之后的使用中可以直接使用 cnpm 替换 npm
npm install -g cnpm --registry=https://registry.npm.taobao.org
php 7.3
安装 php 7.3
sudo apt install php7.3-fpm
使 fastcgi 监听端口
fastcgi 默认监听 /run/php/php7.3-fpm.sock
文件,按照习惯这里修改为监听 9000 端口
将 /etc/php/7.3/fpm/pool.d/www.conf
中 listen
的值修改为 9000
nginx
安装 nginx
sudo apt install nginx
配置 nginx 解析 php
编辑 /etc/nginx/site-enabled/default
,在 server {}
块中添加如下配置
location ~ \.php(.*)$ { fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_split_path_info ^(.+\.php)(.*)$; fastcgi_param path_info $fastcgi_path_info; fastcgi_param script_filename $document_root$fastcgi_script_name; fastcgi_param path_translated $document_root$fastcgi_path_info; include fastcgi_params; }
替换将 server {}
块中的 index
配置替换为如下
index index.php index.html index.htm;
使用以下命令重启 nginx 和 php-fpm
systemctl restart nginx systemctl restart php7.3-fpm
访问 http://127.0.0.1/
测试 nginx 是否配置成功
nginx 的 web 根目录默认位于 /var/www/html/
目录,在该目录下创建 index.php 文件,写入如下代码并访问 http://127.0.0.1/
测试 php 可用性
<?php phpinfo(); ?>
测试完成后删除 index.php
中的内容
0x07 应用安装及配置
chrome 浏览器
下载 chrome 并安装
wget https://dl.google.com/linux/direct/google-chrome-stable_current_amd64.deb sudo apt install ./google-chrome-stable_current_amd64.deb
free download magager 5
fdm5 是一个开源下载器
访问 fdm5 官网 下载安装包
sudo apt install ./freedownloadmanager.deb
在 chrome 中安装 free download manager 扩展,可接管浏览器下载行为
sarasa term sc 字体
这是一个开源的等宽字体,中文名为 更纱黑体 ,该字体可以解决在 chromium 内核中等宽字体渲染错误导致不等宽的问题(例如 yahei consolas hybrid 在 vscode 中)
虽然这个字体一开始用会觉得很奇怪,用习惯了还挺好看
访问 sarasa github 下载 sarasa-gothic-ttf-x.xx.x.7z
格式的 release 包
注意:该字体包中包含了多种字体,我们只需要双击 sarasa-term-sc 开头的字体并点击右上角 安装 即可
mysql workbench
sudo apt install mysql-workbench
vscode
安装 vscode
访问 vscode 官网 点击 .deb 开始下载
sudo apt install ./code_x.xx.x-xxxxxxxxxx_amd64.deb
插件推荐
- chinese (simplified) language pack for visual studio code
- c/c++
- eslint
- markdown all in one
- markdownlint
- polacode
- project manager
- python
-
remote development
- remote - containers
- remote - ssh
- remote - ssh: editing configuration files
- remote - wsl
- todo tree
将以下配置写入 setting.json(vscode 的用户配置文件)
{ "editor.fontfamily": "sarasa term sc", "editor.mousewheelzoom": true, "editor.fontsize": 16, "todo-tree.tree.showscanmodebutton": false }
网易云音乐
访问
右上角 下载全部客户端 -> linux版 -> ubuntu 18.04(64位)
sudo apt install ./netease-cloud-music_x.x.x_amd64_ubuntu_xxxxxxxx.deb
vlc
开源播放器
sudo apt install vlc
filezilla
开源 ftp 客户端
sudo apt install filezilla
telegram
加密即时通讯
sudo apt install telegram-desktop
postman
http 请求模拟/测试
安装 postman
访问 postman 官网,点击 download 下载
将解压后的文件夹移动至 /usr/local
下
postman 桌面图标
在 /usr/share/applications/
目录下为其建立桌面图标 postman.desktop
并写入如下配置
[desktop entry] version=1.0 name=postman genericname=postman comment=postman exec=/usr/local/postman/postman terminal=false icon=/usr/local/postman/app/resources/app/assets/icon.png type=application categories=development
修改 postman 工作目录
postman 默认将工作文件放在用户 home 目录下且不隐藏
这里将 settings -> general -> working directory -> location 修改为 /home/user/.postman/
目录
meld
开源文件/文件夹 diff + merge 工具
sudo apt install meld
hmcl
minecraft 第三方启动器
注意:确保本地配置了 jdk 环境且
java
命令可用
安装 hmcl
访问 hmcl 官网 下载 .jar 包
下载后将其重命名为 hmcl.jar
创建启动脚本
创建启动脚本 hmcl.sh
,便于桌面调用
#!/bin/bash hmcl_path="/usr/local/minecraft" hmcl_name="hmcl.jar" cd $hmcl_path && java -jar $hmcl_name
赋予其执行权限
chmod +x hmcl.sh
下载 logo 并将其重命名为 logo.png
logo 来自 hmcl 官方 github 的资源目录,同级目录下有其他 logo 可供使用,以下为可用的 logo 链接列表
在 /usr/local
目录下建立 minecraft
文件夹,将 hmcl 的 jar 包,启动脚本和 logo.png
移动到该目录中
hmcl 桌面图标
在 /usr/share/applications/
目录下为其建立桌面图标 hmcl.desktop
[desktop entry] version=1.0 name=hmcl genericname=hello minecraft! launcher comment=a minecraft launcher which is multi-functional, cross-platform and popular exec=/usr/local/minecraft/hmcl.sh terminal=false icon=/usr/local/minecraft/logo.png type=application categories=game
修改下载缓存位置
启动器设置 -> 文件下载缓存目录 修改为 /usr/local/minecraft/.minecraft/
目录
注意:需要将 hmcl 下载源修改为官方源才能正常安装 fabric
jetbrains 系列 ide
这里使用 idea 举例
访问 jetbrains 官网,顶部 tool 选择要下载的 ide,跳转后点击 download ,下载 ultimate 或 professional 版本
解压后将其放在 /usr/local/
目录下,其可执行程序一般位于 ide文件夹/bin/
目录下,例如 idea/bin/idea
,使用 user 用户运行,在配置过程中会自动创建桌面图标,无需用户配置
开始配置前请务必参考 知了 blog