Linux批量配置神器zsh.sh

點這裏排版好

19.05.03 Update Vscode 配置攻略(都是血和淚換來的)

上一篇講了很多 Mac 中配置的小技巧如何給碼農 ?‍?‍ 的 Mac 開光

時隔半年,再來詐屍更新一下開光 ? 系列。

每次當我們看到 dalaos 寫的教程時候,雖然一條條都列的很詳細了,但實際操作起來還是困難重重。
有沒有一種更舒適的方式讓我們更容易的獲得教程中所搭建的環境。

對於博主來說,除了上述原因之外,主要是遇到一個很現實的問題,

一開始你可能只是一個實驗室的小磚工
你手上的機子可能還是要去排隊才能輪的上的

沒有可以持久使用的機子,肯定不會去想要不要給服務器配一下 zsh,讓大家登機子上去好用一點
(這個業務場景不考慮做一些內部使用的系統,提升用戶體驗,不存在的)

直到有一天 (當然這一天很可能不存在),大老闆 看你骨骼清奇,說給你 5 張 V100 用一下

你喜出望外,一臉色眯眯,等想着自己是不是要給服務器整一套好用的環境

但是 一個星期過去了,你發現你還在配環境(當然 週報有東西寫 是好事情 hhh)

有時候,一件事做幾次可能會挺有收穫的,但一旦重複次數多了,只剩下厭倦了。

而作爲一個 zsh 深度用戶,在白板 linux 上敲命令總感覺少了些什麼

zsh.sh就是爲了解決這個問題,也爲了方便新手能容易的配置之前教程中說明的環境

  • 如果你手上有一些機器,或者正準備遷移自己的服務器
  • 如果你苦於繁瑣的配置過程,害怕配置中遇到 bug
  • 如果你不喜歡白板 shell 界面,習慣於 zsh 環境

歡迎使用zsh.sh

image

  • 目前支持 Ubuntu, CentOS, MacOSX 三個發行版
  • 支持 amb64(64bit) & i386 (32bit)
  • 支持 Docker 部署,Ubuntu, Ubuntu32, CentOS 三個版本
  • 目前 zsh.sh 中包含 oh-my-zsh,fzf,vimrc 三塊的配置

在使用過程中,肯定會有一些小困難,歡迎在 issue 或者評論區跟我交流。?

image

個人感覺使用起來,還是蠻爽的。科技解放生產力~

Vscode

VSCode 真香

VSCode 真香

VSCode 真香

image

hhh 之前我一直是 Sublime 佈道者,VSCode 黑

直到最近,主力 IDE 已經變成 VSCode 了

特別是最近 VSCode 正式發佈vscode-remote

第一眼 看到的時候 震驚了!!!

這意味着以後你可以在服務器上用 VSCode 寫代碼,這還要什麼coder-server

先鞭屍一下 coder-server, 相較於 vscode-remote:

  • coder-server, 橫向擴展性差,必須在相應的服務器上部署 coder-server
  • 配置麻煩,我們本地 local 的 VSCode 肯定會花大力氣配置,但如果有 n 臺服務器呢,你還會這麼做嗎(寫個腳本,不好意思,這個有點難寫)
  • 所以一開始看到 code-server 的時候沒有那麼驚喜,(流露出配過環境的人的眼淚 ?

試驗下來超級順滑,除了現在 vscode-remote 只支持 64bit 的 Linux 這一點,其他都很絲滑(Nachos 還是不能用 hhh

除了支持 ssh 連接之外,還支持 Docker Container 的連接,超級棒了

但 vscode-remote 目前出於公測階段,只能在綠色的 VSCode Insider 中使用,而且功能還待完善

image

給我個理由

那麼作爲一個忠實的 Sublime 用戶,爲何會從 Sublime 遷移到 VSCode 來

當時覺得 Sublime 有幾點特別吸引我:

  1. 好看
  2. 輕量
  3. 可配置實現 ide 喚起編譯運行
  4. 保存時自動調整代碼格式
  5. 寫 cpp 的時候模板用起來特別爽
  6. 可以設置帶有 File Header

而這些 我都在 VSCode 中一個個實現了

因爲 之前配置的 Vscode 裝插件裝的特別多 在代碼量特別大的時候(7k-8k 行),code help 進程就會打滿,整個機子就會石樂志一樣

再加上 vscode-remote 只支持 Insider 版,就順道把配置理了一下

Save Format

這裏用到的是Formatting Toggle + Prettier這個插件,支持的文件類型還是比較多的,比如給 markdown 表格自動格式化,這還是挺酷炫的

image

{
  "formattingToggle.activateFor": ["formatOnSave"],
  "editor.formatOnSave": true,
  "files.autoSave": "onFocusChange"
}

File Header

這個用了psioniq File Header, 文檔還是比較詳細的,但配置十分繁瑣,弄了好長時間,還給作者發郵件,hhh

{
  "psi-header.changes-tracking": {
    "autoHeader": "autoSave",
    "isActive": true,
    "modDate": "@Last Modified time: ",
    "modAuthor": "@Last Modified by:   ",
    "include": [],
    "exclude": ["markdown", "json"],
    "excludeGlob": ["out/**", "src/**/*.xyz"]
  },
  "psi-header.config": {
    "forceToTop": true,
    "blankLinesAfter": 1,
    "author": "gunjianpan",
    "authorEmail": "[email protected]",
    "license": "Custom"
  },

  "psi-header.lang-config": [
    {
      "language": "python",
      "begin": "",
      "prefix": "# ",
      "end": "",
      "beforeHeader": ["# -*- coding: utf-8 -*-"]
    },
    {
      "language": "shellscript",
      "begin": "",
      "prefix": "# ",
      "end": "",
      "beforeHeader": ["#!/bin/bash"]
    },
    {
      "language": "javascript",
      "begin": "/**",
      "prefix": " * ",
      "end": " */",
      "blankLinesAfter": 2,
      "forceToTop": false
    },
    {
      "language": "typescript",
      "mapTo": "javascript"
    }
  ],
  "psi-header.templates": [
    {
      "language": "*",
      "template": [
        "@Author: <<author>>",
        "@Date:   <<filecreated('YYYY-MM-DD HH:mm:ss')>>",
        "@Last Modified by:   <<author>>",
        "@Last Modified time: <<dateformat('YYYY-MM-DD HH:mm:ss')>>"
      ]
    }
  ]
}

代碼編譯運行

雖然提供了在 Output 中輸出運行結果的插件Code Runner

但很多場景是需要交互式的,(比如說刷 leetcode ??

這個時候 就需要配置一下

{
  "code-runner.executorMap": {
    "javascript": "node",
    "perl": "perl",
    "go": "go run",
    "python": "ipython3",
    "java": "cd $dir && javac $fileName && /Library/Java/JavaVirtualMachines/jdk1.8.0_181.jdk/Contents/Home/bin/java '-javaagent:/Applications/IntelliJ IDEA.app/Contents/lib/idea_rt.jar=60957:/Applications/IntelliJ IDEA.app/Contents/bin' -Dfile.encoding=UTF-8 -classpath $dir $fileNameWithoutExt",
    "c": "cd $dir && /usr/bin/gcc $fileName -o $fileNameWithoutExt && open -a Terminal.app $dir$fileNameWithoutExt",
    "cpp": "cd $dir && /usr/bin/g++ -std=c++11 $fileName -o $fileNameWithoutExt && $dir$fileNameWithoutExt"
  }
}

能像 Intellij IDEA 一樣能查 local History

Local History

{
  "local-history.daysLimit": 30,
  "local-history.maxDisplay": 16,
  "local-history.saveDelay": 0,
  "local-history.dateLocale": "en-GB",
  "local-history.exclude": [
    "**/.history/**",
    "**/.vscode**",
    "**/node_modules/**",
    "**/typings/**",
    "**/out/**",
    "**/__pycache__/**",
    "**/.ipynb_checkpoints/**",
    "**/data/**",
    "**/.DS_Store/**",
    "**/checkpoint/**"
  ]
}

Live Share

然後比較推薦的時候 Vscode 的 Live Share, 這是我隊友給我推薦的

你可以用 Live share 多人寫代碼,也可以用來作爲遠程 Terminal 幫忙調試的媒介

一鍵召喚神龍

Latex

Vscode 畢竟是宇宙第一操作系統, 在上面敲 Latex 也是很爽的,配上 Latex 公式神器Mathpix snipping Tool

image

image

Other

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章