鍍金池/ 問(wèn)答/ Linux問(wèn)答

通過(guò)socket發(fā)送一個(gè)文件流程大概如下:

  1. 打開(kāi)文件
  2. 把文件數(shù)據(jù)讀到內(nèi)存
  3. 把內(nèi)存里的數(shù)據(jù)寫(xiě)到socket

Nginx通過(guò)open_file_cache可以減少重復(fù)打開(kāi)文件,然后通過(guò)sendfile系統(tǒng)調(diào)用減少內(nèi)核空間和用戶空間間的內(nèi)存復(fù)制,直接把文件內(nèi)存寫(xiě)到socket,通過(guò)這些就能對(duì)單次返送進(jìn)行優(yōu)化。

再加上Nginx的高效的事件處理機(jī)制,就能支持高并發(fā)。

歆久 回答

你這個(gè)是二級(jí)域名的問(wèn)題,我找到一個(gè)更簡(jiǎn)單一點(diǎn)的教程https://blog.csdn.net/shoyin/...
還有就是要記得建立二級(jí)域名的A記録,像這樣,記録值填I(lǐng)P
圖片描述

還吻 回答

更改服務(wù)器的端口后,可以了。

clipboard.png

這個(gè)很坑,阿里云根本沒(méi)維護(hù)過(guò)這個(gè)鏡像,而且還堂而皇之的掛在官方網(wǎng)站上。

這個(gè)鏡像從來(lái)就無(wú)法使用,建議直接使用阿里云的云服務(wù)上的docker鏡像https://www.aliyun.com/produc... (免費(fèi)的,開(kāi)通之后本地也可以使用),或者中科大的: https://mirrors.ustc.edu.cn/h...

離觴 回答

xinput 使用方法:xinput set-prop <device> <property> <val>
其中 device 可以使用名字,也可以使用 設(shè)備ID,因?yàn)槟氵@里有 2 個(gè)同名的,用名字肯定不行,所以要用 ID;property 可以是名字,也可以是 Atom 值(也是一個(gè)數(shù)),查看方法是 xinput list-props <device>

黑與白 回答

可以考慮使用concurrent.futures中的ThreadPoolExecutor

from concurrent.futures import ThreadPoolExecutor
executor = ThreadPoolExecutor(2) #參數(shù)為要再開(kāi)的線程數(shù)
...
executor.submit(your_function)
黑與白 回答

redirect和forward是不同的。redirect是服務(wù)端告訴客戶端,你要訪問(wèn)下一個(gè)鏈接,這個(gè)時(shí)候如果不是把參數(shù)放在session等區(qū)域是不能保存信息的,等于這個(gè)時(shí)候如果要傳遞token,要么把token放在url上redirect;要么用服務(wù)器端的一個(gè)地方保存一下這個(gè)token,一般是session,看你的需求,使用redirect之后,才能訪問(wèn)到token。

這個(gè)是百度蜘蛛的UserAgent吧,如果想要網(wǎng)站不被抓取。
可以配置 robots.txt ,拒絕所有抓取;這樣這些請(qǐng)求就不會(huì)來(lái)了,自然就不用處理。

生性 回答

ajax請(qǐng)求是異步的啊...感覺(jué)你的clearInterval應(yīng)該可能是清除了定時(shí)器但是無(wú)法停止ajax操作吧...

柒喵 回答

自己寫(xiě)一個(gè)簡(jiǎn)易webpack插件就可以了。示例代碼:

{
  plugins: [
    function() {
      // 修改package.json中的版本號(hào)
      this.plugin('done', function() {
        const pkgPath = path.join(__dirname, '/../package.json');
        let pkg = fs.readFileSync(pkgPath);
        pkg = JSON.parse(pkg);
        pkg.version = '1.0.1';
        fs.writeFileSync(pkgPath, JSON.stringify(pkg, null, 2));
      });
    },
    new webpack.DefinePlugin({
      'process.env.MY_VERSION': JSON.stringify(require('../package.json').version)
      // 項(xiàng)目中使用 process.env.MY_VERSION 輸出
    })
  ];
}
玄鳥(niǎo) 回答

主要的解決方案有兩種:

利用插件管理器的 on-demanding loading

現(xiàn)在插件管理器用戶比較多的是 vim-plugdein,都支持這種按需加載. 我用的是 vim-plug, 以 vim-plug 為例:

Plug 'scrooloose/nerdtree', { 'on': ['NERDTreeToggle', 'NERDTreeFind'] }
augroup loadNerdtree
autocmd!
autocmd VimEnter * silent! autocmd! FileExplorer
autocmd BufEnter,BufNew *
          \  if isdirectory(expand('<amatch>'))
          \|   call plug#load('nerdtree')
          \|   call nerdtree#checkForBrowse(expand("<amatch>"))
          \| endif
augroup END

詳情見(jiàn) 這里 ,在用到該命令時(shí)再進(jìn)行加載。

使用這一方法來(lái)加載那些不常用或者無(wú)須啟動(dòng)時(shí)加載的插件,比如 nerdtree, vim-javacomplete2, ctrlp 等等。更多內(nèi)容可以參考 space-vim 中 layer 下面的 packages.vim 里面的用法。


利用定時(shí)器 api timer_start

space-vim 就用了這個(gè)方法進(jìn)行了加速,詳情見(jiàn) 這里 , 靈感來(lái)自于 Reddit 上的一個(gè)帖子。timer_start() 對(duì) vim 的版本有一定要求,不過(guò) vim8 和 neovim 都是已經(jīng)有了,:echo exists('*timer_start') 看一下是否存在。

基本用法是在插件管理器中設(shè)置不加載該插件,然后在timer_start 的回調(diào)中進(jìn)行加載:

" 'on':[] 在 vim-plug 中表示不加載該插件
Plug 'easymotion/vim-easymotion'           , { 'on': [] }

" 500 毫秒后調(diào)用 LoadPlug,且只調(diào)用一次, 見(jiàn) `:h timer_start()`
call timer_start(500, 'LoadPlug')

function! LoadPlug(timer) abort
  " 手動(dòng)加載 vim-easymotion
  call plug#load('vim-easymotion')
endfunction

space-vim 用到的插件應(yīng)當(dāng)說(shuō)不少,但是啟動(dòng)時(shí)間基本不超過(guò) 100 ms。

雅痞 回答

現(xiàn)在在分支prod上,想切換分支到dev上,如果沒(méi)有commit:

git stash
git checkout dev
git pop

如果commit了,去dev分支merge prod分支,然后回到prod分支回退版本

離觴 回答

你用的是virtualbox虛擬機(jī)嗎?那個(gè)是virtualbox guest的源碼包,需要你實(shí)現(xiàn)安裝編譯依賴(lài)(比如kernel-devel, gcc, make, perl等等),然后運(yùn)行那個(gè)run腳本。注意那個(gè)run腳本在光盤(pán)中是不具有可執(zhí)行權(quán)限的,不能直接雙擊運(yùn)行,必須拷貝出來(lái),賦可執(zhí)行權(quán)限,在終端下交互式運(yùn)行。

see: https://www.tecmint.com/insta...

紓惘 回答

data(){

form:{
    token:"123"
}

}
這樣設(shè)置。

傻叼 回答

拿tomcat里的request來(lái)舉例,

https://tomcat.apache.org/tom...

tomcat里的是具體實(shí)現(xiàn),而servlet的request僅僅是接口而已,正如你題目中所說(shuō)的規(guī)范。

用netty 實(shí)現(xiàn) servlet規(guī)范,可以看看這個(gè)project:https://github.com/bigpuritz/...

后端解析頁(yè)面的時(shí)候判斷頁(yè)面中的連接是否為本站地址 主要是判斷域名

如果不是就將該地址完全替換掉,如果是就不做什么處理!

第二種利用js:當(dāng)a被點(diǎn)擊的時(shí)候先組織,獲取到點(diǎn)擊的連接地址進(jìn)行判斷

在你點(diǎn)擊連接的時(shí)候已經(jīng)跳轉(zhuǎn)到別的服務(wù)器了, nginx實(shí)現(xiàn)的幾率可能不大

野橘 回答

手動(dòng)測(cè)試一下吧。

sudo mv xx-access.log xx-access.log-20171113
sudo kill -USR1 $(cat /var/run/nginx.pid)

也可以試下以下命令重新打開(kāi)日志文件

sudo nginx -s reopen
挽青絲 回答

解決了 解決方式參見(jiàn)這個(gè)博客 http://www.fayfox.com/post/39...