[linux] 上手新ubuntu机器的初始化工作(自用侵删)

2024-06-08 20:12

本文主要是介绍[linux] 上手新ubuntu机器的初始化工作(自用侵删),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 环境类
    • Vim
    • zsh
    • other
  • 应用类
    • Typora
      • 激活环境准备
      • 解包替换文件app.asar
      • 激活Typora
    • VsCode
      • extension
      • .vscode
      • 乱码
    • WattToolkit
    • QQ
    • WPS
    • 输入法:Fcitx
    • Deepin-wine : Wechat

环境类

Vim

直接贴配置

vim-Plug:

let mapleader = ","
let g:mapleader = ","
let maplocalleader = ","
"NerdTree
nnoremap <leader>n :NERDTreeFocus<CR>
nnoremap <leader>m :NERDTree<CR>
nnoremap <leader>t :NERDTreeToggle<CR>
nnoremap <leader>f :NERDTreeFind<CR>"快捷键修改"set tabstop=4 "tab键位数"
set shiftwidth=4 "自动缩进位数"
set number
imap jk <ESC>
nmap <space> :
"vim-Plug 下载"
call plug#begin('~/.vim/plugged')
Plug 'vim-airline/vim-airline'
Plug 'vim-airline/vim-airline-themes'
Plug 'scrooloose/nerdtree'
Plug 'luochen1990/rainbow'
Plug 'scrooloose/nerdcommenter'
Plug 'altercation/vim-colors-solarized'
Plug 'jiangmiao/auto-pairs'
Plug 'Valloric/YouCompleteMe'
call plug#end()"配置"vim-airline"set laststatus=2  "永远显示状态栏"
let g:airline_powerline_fonts = 1  " 支持 powerline 字体"
let g:airline#extensions#tabline#enabled = 1 "显示窗口tab和buffer"
let g:airline_theme='bubblegum'if !exists('g:airline_symbols')let g:airline_symbols = {}
endif
let g:airline_left_sep = '▶'
let g:airline_left_alt_sep = '❯'
let g:airline_right_sep = '◀'
let g:airline_right_alt_sep = '❮'
let g:airline_symbols.linenr = '¶'
let g:airline_symbols.branch = '⎇'"airline end" nerd - commenter
" Add spaces after comment delimiters by default
let g:NERDSpaceDelims = 1" Use compact syntax for prettified multi-line comments
let g:NERDCompactSexyComs = 1" Align line-wise comment delimiters flush left instead of following code indentation
let g:NERDDefaultAlign = 'left'" Set a language to use its alternate delimiters by default
let g:NERDAltDelims_java = 1" Add your own custom formats or override the defaults
let g:NERDCustomDelimiters = { 'c': { 'left': '/**','right': '*/'} }"Allow commenting and inverting empty lines (useful when commenting a region)
let g:NERDCommentEmptyLines = 1" Enable trimming of trailing whitespace when uncommenting"
let g:NERDTrimTrailingWhitespace = 1" Enable NERDCommenterToggle to check all selected lines is commented or not"
let g:NERDToggleCheckAllLines = 1" vim-rainbow{}
let g:rainbow_active = 1" vim-color- solarized
if has("gui_runing")              "如果在图形用户界面set background=light          "设置背景色为亮色
else                              "设置背景色为深色set background=dark           "就开启256色支持,默认为8色set t_Co=256
endif
let g:solarized_bold=0
let g:solarized_underline=1" vim-autopairs
au Filetype FILETYPE let b:AutoPairs = {"(": ")"}
au FileType php      let b:AutoPairs = AutoPairsDefine({'<?' : '?>', '<?php': '?>'})let g:ycm_server_python_interpreter="/usr/bin/python3"
let g:ycm_global_ycm_extra_conf="~/.vim/plugged/YouCompleteMe/third_party/ycmd/examples/.ycm_extra_conf.py""

zsh

1.zsh:

sudo apt install zsh

2.oh-my-zsh:

Basic install:

Oh My Zsh is installed by running one of the following commands in your terminal. You can install this via the command-line with either curl, wget or another similar tool.

MethodCommand
curlsh -c "$(curl -fsSL https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)"
wgetsh -c "$(wget -O- https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)"
fetchsh -c "$(fetch -o - https://raw.githubusercontent.com/ohmyzsh/ohmyzsh/master/tools/install.sh)"

from : https://github.com/ohmyzsh/ohmyzsh

3.powerlevel10k
一个zsh主题


plugin:

 plugins=(gitzsh-history-substring-searchzsh-autosuggestionszsh-syntax-highlighting)

以autosuggestiongs为例:
找到插件对应仓库,然后git clone

git clone https://github.com/zsh-users/zsh-autosuggestions $ZSH_CUSTOM/plugins/zsh-autosuggestions


other

  • gcc / g++

    sudo apt update
    sudo apt install build-essential
    
  • git

  • yum

  • rpm

  • Alien

Alien是用来将 rpm 包转换成 deb 包的。
rpm文件不能直接被安装,需要转换成 deb。
ubuntu 的安装包格式是 deb。

  • shell有zsh或者fish,
  • 编辑器有neovim或者emacs
  • 文件浏览有ls和ranger版本控制有lazygit
  • 终端复用有tmux

还可以换的玩具有:
cgdb valgrind rr make autotools cmake meson xmake

示例图
在这里插入图片描述


应用类

Typora

支持typora版本1.0.3
本人已测试平台:Ubuntu22.04

激活环境准备

  • 相关依赖

安装Python3、Python3-pip

安装nodejs

sudo apt-get install nodejs
  • 克隆typoraCraker项目
git clone https://github.com/cnvetman/typoracracker.git
  • python相关依赖

切换到克隆下来的项目根目录typoracracker下执行:

pip3 install -r requirements.txt
  • **下载Typora1.0.3版本

项目目录下有typora_1.0.3的deb包,执行下面命令直接安装即可。

dpkg -i typora_1.0.3_amd64.deb

解包替换文件app.asar

以下操作都是切换到typoraCracker项目根目录下执行

注意,强烈建议在解包原生文件到~/Desktop中

  • 解包原生app.asar

安装Typora后,原生app.asar文件默认路径是/usr/share/typora/resources/app.asar;

解包原生app.asar文件:

python3 typora.py /usr/share/typora/resources/app.asar ~/Desktop/  
#解包后,在桌面会有一个`dec_app`目录
  • 修改License.js

修改dec_app目录中的License.js;在typoraCracker项目下,提供有修改好的License.js,所以直接替换即可:

  cp example/patch/License.js ~/Desktop/dec_app/
  • 生成app.asar
python3 typora.py -u ~/Desktop/dec_app ~/Desktop
# 在~/Desktop路径下,会生成新的的app.asar文件替换app.asar
  • 替换app.asar

将Typora原生的的app.asar文件替换:

# 备份原生app.asar文件
sudo cp /usr/share/typora/resources/app.asar /usr/share/typora/resources/app.asar.bak    
# 用新生成的app.asar文件替换typora自带的app.asar文件
sudo cp ~/Desktop/app.asar /usr/share/typora/resources/app.asar         

激活Typora

在typoraCracker项目根路径下,执行keygen.js脚本:

生成激活码

node example/keygen.js

得到激活码后,打开Typora软件 --> Typora帮助 --> 我的许可证 --> 输入你的激活信息,随便一个邮箱加生成的激活码。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

原文链接:https://blog.csdn.net/weixin_73546177/article/details/132033297


VsCode

extension

  • C++/C extension
  • Code Runner
  • Tabnine AI autocomplete

.vscode

  1. c_cpp_properties.json

    鼠标点在.c的源文件内部,按 Ctrl+Shift+p 快捷键,在弹出的界面中选择: [C/C++:编配置(UI)],然后进入设置页面。

    img

    img

    点进去之后我们要设置我们的编译器路径和IntelliSense 模式:
    (windwos用户可以考虑。我使用ubuntu + gcc没有操作这一步,默认设置)img

    img

  2. tasks.json

    创建执行任务 task.json

    要编译代码,我们接下来,在终端中:配置任务,如下图:

    img

    然后选择gcc.exe:

    img

    打开之后就会出现一个新的文件夹:这个文件是专门来执行编译任务的。

    img

原文链接:https://blog.csdn.net/Yikefore/article/details/130033638

  1. launch.json

    Right click , then click “Add Debug Configuration.”

乱码

ubuntu使用 Visual Studio Code 运行C程序时终端(控制台)上显示:

result [1] + Done “/usr/bin/gdb” --interpreter=mi --tty=${DbgTerm} 0<"/tmp/Microsoft-MIEngine-In-b608v45i.py3" 1>"/tmp/Microsoft-MIEngine-Out-42xjb3vz.7lk"

解决方式

在 launch.json 文件中的 configurations 字段中添加一项

"miDebuggerArgs": "-q -ex quit; wait() { fg >/dev/null; }; /bin/gdb -q --interpreter=mi",

再次运行C程序就不会出现不需要的信息了!
————————————————

版权声明:本文为博主 九思梦鹿 原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

原文链接:https://blog.csdn.net/WU2629409421perfect/article/details/113357420


下面这三个软件没什么好说的。
观望下deb包,然后sudo dpkg -i 就OK了。
不过让我长见识的是,Ubuntu 桌面应用的快捷方式,竟然要到/usr/share/applications这个目录下,找到.desktop文件,右键选择allow launching,这个应用才能从黑色变成红色,名字也自动变成所写。
还蛮神奇的…

  • 话说我一开始发现原来 deb 包就是安装包,dpkg -i就是安装的时候,我震惊了;
  • 发现桌面快捷方式是.desktop文件,而且要allow launching才能浮现真容的时候,我又一次震惊了。
  • 发现/usr/bin下面的都是系统预装的可执行程序(命令),我还因为多敲了一个空格,sudo rm了bin目录的所有文件的时候,我又又又震震震惊了
    ——在被锁屏页面将我的急救备份文件拒之门外的时候,我笑了笑,感叹自己二十二岁已经历了人生一次大起大落而笑了。
    于是重装系统喽。(现在看来,这篇文章以及 Ubuntu 全部 Bug 的解决没有辜负自己两天心流的努力呀!😀)

(ps: /usr/local/bin目录是给用户放置自己的可执行程序.,不会被系统升级而覆盖同名文件。)

WattToolkit

QQ

WPS

输入法:Fcitx

6.4.2024
输入法。逆天输入法,总是卡QT 和GTK文件。一开始用fcitx4 GTK全部不兼容。后来用fcitx5 ,支持火狐浏览器和终端用了。自己下载的桌面应用程序还是用不了。逆天


6.6.2024
更新。可以用了,两天没开电脑,今天上网搜了搜,无意中发现我的Typora、WPS 和QQ 这类桌面应用程序都能用了。
但是这个时候fcitx-diagnose还是会有报错。
至少说明这些错误和“是否支持桌面程序”无关。

4.fcitx-remote:
无法连接到 fcitx.

5.DBus 界面:
使用 dbus-send 来检查 dbus。
找不到 DBus 名称 org.fcitx.Fcitx 的所有者。
找不到 DBus 名称 org.fcitx.Fcitx 的 pid 所有者。
2.用于 GTK±2.0 的配置界面:
未找到 gtk2 的配置界面.
2.根窗口上的 XIM_SERVERS:
Xim 服务名称: “fcitx5” 与环境变量中设置的值 “fcitx” 不同.
3.QT输入法模块文件
无法找到 Qt4 的 fcitx 输入法模块.

4.用户界面
无法找到 kimpanel dbus 接口或非 kimpanel 用户界面.

但也不排除是因为我运行了这个指令

sudo apt-get install fcitx-libs-dev                                        

把最后欠缺的依赖给安装上了。
AnyWay,属于是柳暗花明又一村了。

这次经历让我懂得了:
1.用 sudo rm 时请抱好极大求生欲
2.Github 要学会看 issue
3.少用百度搜,都是来回的copy.
用Bing更好。

Deepin-wine : Wechat

在 fcitx 的 issue 里找解决方案的时候,我无意中发现了 deepin-wine-ubuntu这个仓库。这玩意居然能装微信!
不需要借助 铜豌豆 这种庞然大物,用Docker解决微信安装问题确实是不错的实践。
后续我会找机会把微信这个BOSS拿下。
现阶段可以说除微信外的所有BUG 、APP 都已经拿下了。

奥,除了唯一的小问题:为什么 zsh 的 plugins 失效了,不给我自动补全和高亮。
可恶。
vim-Plug 也还没安上呢。

OK ,一身轻松。可以歇歇了。
如果这个东西是你从0到1,一个一个 BUG解决,一个一个零件亲手建设起来的。随手的使用都会有很大的成就感。

比如现在的中文输入法哈哈。
在这里插入图片描述
在这里插入图片描述


所有问题已解决。收心学数学去了。

  1. zsh插件没查到是因为.zshrc里原来的 plugins 没看到,写了两个plugin。
  2. fcitx输入法有两个版本:fcitx4fcitx5。我的ubuntu22.0不支持4,支持5。
  3. Vim-Plug 安装时总连接不上Github。换源后完美解决。(改plug.vim两处)
  4. docker和虚拟机貌似也能实现微信。但我目前没有这个心思去研究docker,再把微信移植过去。所以先用简单易用的deepin-wine吧。
  5. 微信这类官方不支持的应用可以用wine解决。wine再往上一层,就是我所用的github项目:deepin-wine

deepin-wine 有两个版本,一个wszqkzqk,一个zq1997
两个rep都有5k+的star,但是wszqkzqk的 wine 22年就不再维护,关闭了issue。
zq的一直在更新。所以用他的了。(实际上w的我尝试过但没有安装成功)

关于wine

  • wine 运用API转换技术实做出Linux对应到Windows相对应的函数来调用DLL以运行Windows程序。Wine 允许在 Linux 和其他类 Unix 操作系统上运行 Windows 应用程序的兼容层。
  • Wine是自由软件,在GNU通用公共许可证(LGPL) 下发布。名称是 “Wine Is Not an Emulator” 的缩写(Wine不是Windows模拟器,)。
  • Wine 通过提供一套模拟 Windows API 的库,使得许多 Windows 程序能够在 Linux 系统上运行,而无需对源代码进行修改。

Deepin-Wine 是一个开源项目,它基于 Wine(Wine Is Not an Emulator)进行开发,旨在优化 Wine 在 Linux 系统上的体验,特别是针对深度科技(Deepin)团队维护的 Linux 发行版


一种未来的应用方案:用Windows + WSL,在WSL中搭建开发环境,Windows Terminal做终端。

这篇关于[linux] 上手新ubuntu机器的初始化工作(自用侵删)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1043194

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

linux-基础知识3

打包和压缩 zip 安装zip软件包 yum -y install zip unzip 压缩打包命令: zip -q -r -d -u 压缩包文件名 目录和文件名列表 -q:不显示命令执行过程-r:递归处理,打包各级子目录和文件-u:把文件增加/替换到压缩包中-d:从压缩包中删除指定的文件 解压:unzip 压缩包名 打包文件 把压缩包从服务器下载到本地 把压缩包上传到服务器(zip

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

线性代数|机器学习-P36在图中找聚类

文章目录 1. 常见图结构2. 谱聚类 感觉后面几节课的内容跨越太大,需要补充太多的知识点,教授讲得内容跨越较大,一般一节课的内容是书本上的一章节内容,所以看视频比较吃力,需要先预习课本内容后才能够很好的理解教授讲解的知识点。 1. 常见图结构 假设我们有如下图结构: Adjacency Matrix:行和列表示的是节点的位置,A[i,j]表示的第 i 个节点和第 j 个