Remove Annoying startup Advertisement of X-TV via Pi-Hole

谁TMD买X电视” 是一款性价比很高的电视,受到很多年轻人的青睐,对于偶尔看看剧,电影的,对画质没有那么高要求的我,也选择了它,虽然内心是Sony大法好,奈何钱包君暂时不给力,哈哈哈。

言归正传,”谁TMD买X电视”虽然性价比高,但也有一个令人很厌烦的事情,那就是它那变态的启动广告,虽然内心可以理解”谁TMD买X电视”通过自启加载广告来获得广告营收,但很多人包括我还是比较诟病自启广告的。那么问题来了,我们该如何去Block这些广告呢。其实思路很简单。”谁TMD买X电视”具体加载广告的逻辑我并不是很清楚,有可能是首次启动时自动加载上次以存在本地的广告cache,也有可能是启动时,向某厂商的广告服务器发起请求以获取广告资源,这两点有个共通点那就是大概率会进行DNS query。那么我们自己实现一个DNS服务器,然后将”谁TMD买X电视” 请求的指向loopback address (127.0.0.1)。

前人种树,后人乘凉。Pi-Hole就是一款特别适合这样场景的软件。具体阁下可能需要一个树莓派用来承载Pi-Hole,项目地址:https://github.com/pi-hole/pi-hole 。安装Pi-Hole非常简单,使用下面这条命令:

curl -sSL https://install.pi-hole.net | bash

安装过程中请将您的树莓派连接至网络,因为Pi-Hole在安装的时候会安装一些raspberry OS的一些依赖,具体的安装步骤我就不在此赘述,有Linux基础的同学肯定都会,如果不会可以自行Google 或者 Bilibili。 :)

安装完之后,可以打开Pi-hole的Admin Web页面进行查看

接下来我们需要将 “谁TMD买X电视” 的网络设置进行调整,自定义其DNS服务器为我们刚刚设置好的Pi-hole,值得一提的是,Pi-hole的默认规则里面居然自动block 某厂商的广告域名,我当时就惊了,真的是开箱即用。

最后,如果阁下不想用这些工具,也可以使用软路由或者高级路由器进行自定义拦截。

Vim for C++ and Go development

工欲善其事,必先利其器。

作为一名能爱折腾的小简子,从高中到现在工作多年的我,尝试过形形色色的编辑器或者IDE,小到nano,大到Visual Studio 、Xcode、 Jetbrains 全家桶系列,但在这么多年中唯一坚持使用的就是Vim

最早接触Vim的时候是在高中的时候,那个时候自己很喜欢玩Backtrack Linux。那个时候的我在BT上学习写C语言程序的时候就拿的是Vim写的。唯一有点可惜的是当时的自己尝试东西都是浅尝辄止,非常可惜,并没有发掘出Vim的优势,只是把它当成一款编辑器去使用,现在想想后悔不已,工作之后更换了HHKB Pro。加上macOS的iTerm2 用Vim 写代码不要太爽,让我无法拒绝Vim。

在配置安装前我们需要准备的。

关于操作系统我推荐:macOS 或者Linux,关于网络环境,由于在天朝的某种不可抗力,这边我们可能需要尝试使用Proxifier或者proxychains4 配合Proxy安装某些依赖。

我使用的是macOS Mojave,Python版本是 3.7.5作为环境 Vim版本为8.1 (手动编译)。

基础配置部分:

"	通用设置
" 关闭兼容模式
set nocompatible

set number " 设置绝对行号
set relativenumber " 设置相对行号
set cursorline "突出显示当前行
" set cursorcolumn " 突出显示当前列
set showmatch " 显示括号匹配

" tab 缩进
set tabstop=4 " 设置Tab长度为4空格
set shiftwidth=4 " 设置自动缩进长度为4空格
set autoindent " 继承前一行的缩进方式,适用于多行注释

" 定义快捷键的前缀,即<Leader>
" let mapleader=";"

" ==== 系统剪切板复制粘贴 ====
" v 模式下复制内容到系统剪切板
vmap <M-c> "+yy
" n 模式下复制一行到系统剪切板
nmap <M-c> "+yy
" n 模式下粘贴系统剪切板的内容
nmap <M-v> "+p

"开启实时搜索
set incsearch
" 搜索时大小写不敏感
set ignorecase
syntax enable
syntax on                    " 开启文件类型侦测
filetype plugin indent on    " 启用自动补全

" 退出插入模式指定类型的文件自动保存
au InsertLeave *.go,*.sh,*.h,*.py,*.cpp,*.hpp write

插件管理部分,我使用更加好用的vim-plug。插件如下:

"==============================================================================
" 使用Plug管理插件
"==============================================================================

" 插件开始的位置
call plug#begin('~/.vim/plugged')

" Vim 中文文档
Plug 'yianwillis/vimcdoc'
" Shorthand notation; fetches https://github.com/junegunn/vim-easy-align
" 可以快速对齐的插件
Plug 'junegunn/vim-easy-align'
" 用来提供一个导航目录的侧边栏
Plug 'scrooloose/nerdtree'
" 可以使 nerdtree Tab 标签的名称更友好些
Plug 'jistr/vim-nerdtree-tabs'
" 可以在导航目录中看到 git 版本信息
Plug 'Xuyuanp/nerdtree-git-plugin'
" 查看当前代码文件中的变量和函数列表的插件,
" 可以切换和跳转到代码中对应的变量和函数的位置
" 大纲式导航, Go 需要 https://github.com/jstemmer/gotags 支持
Plug 'majutsushi/tagbar'
" 自动补全括号的插件,包括小括号,中括号,以及花括号
Plug 'jiangmiao/auto-pairs'
" Vim状态栏插件,包括显示行号,列号,文件类型,文件名,以及Git状态
Plug 'vim-airline/vim-airline'
" 有道词典在线翻译
Plug 'ianva/vim-youdao-translater'
" 代码自动完成,安装完插件还需要额外配置才可以使用
Plug 'Valloric/YouCompleteMe'
" 可以在文档中显示 git 信息
Plug 'airblade/vim-gitgutter'
" 下面两个插件要配合使用,可以自动生成代码块
Plug 'SirVer/ultisnips'
Plug 'honza/vim-snippets'
" 配色方案
" colorscheme gruvbox
Plug 'morhetz/gruvbox'
" colorscheme one
Plug 'rakr/vim-one'
Plug 'altercation/vim-colors-solarized'
" go 主要插件
Plug 'fatih/vim-go', { 'tag': '*' }
" go 中的代码追踪,输入 gd 就可以自动跳转
Plug 'dgryski/vim-godef'
" markdown 插件
Plug 'iamcco/mathjax-support-for-mkdp'
Plug 'iamcco/markdown-preview.vim'
" 自动生成注释的插件
Plug 'scrooloose/nerdcommenter'
" 强大的文件搜索插件
Plug 'junegunn/fzf', { 'dir': '~/.fzf', 'do': './install --all' }
Plug 'junegunn/fzf.vim'
" 格式化代码插件
" 这个插件特定语言需要额外支持, 比如格式化 json, 需要 js-beautify
" 安装可以 yay -S js-beautify(archlinux) 或者 npm install -g js-beautify
" 更多支持参考: https://github.com/Chiel92/vim-autoformat#default-formatprograms
Plug 'Chiel92/vim-autoformat'
" 插件结束的位置,插件全部放在此行上面
call plug#end()

建议使用Proxifier 或者给git做代理使用,如果阁下网络环境在墙外或者家中、公司的网络可以默认走代理请无视。使用:PlugInstall命令即可完成安装。

注意我们使用的生成代码tag,对于Go语言,需要先安装gotags,安装命令为: go get -u github.com/jstemmer/gotags 或者使用 brew install gotags ,若阁下未安装brew 需要先follow https://brew.sh/ 指示进行安装。对于C或者C++语言,我们需要先安装ctags。可以直接使用brew install ctags

插件配置:

Vim 配色配置:

set termguicolors
" 配色方案, 可以从上面插件安装中的选择一个使用
colorscheme one " 主题
set background=dark " 主题背景 dark-深色; light-浅色

Vim-go 配置:

let g:go_fmt_command = "goimports" " 格式化将默认的 gofmt 替换
let g:go_autodetect_gopath = 1
let g:go_list_type = "quickfix"

let g:go_version_warning = 1
let g:go_highlight_types = 1
let g:go_highlight_fields = 1
let g:go_highlight_functions = 1
let g:go_highlight_function_calls = 1
let g:go_highlight_operators = 1
let g:go_highlight_extra_types = 1
let g:go_highlight_methods = 1
let g:go_highlight_generate_tags = 1

let g:go_def_mode = 'gopls'
let g:go_info_mode = 'gopls'
let g:go_def_mapping_enabled = 1
let g:go_code_completion_enabled = 1

" 直接通过 go run 执行当前文件
autocmd FileType go nmap <leader>r :GoRun %<CR>

NERDTree 插件:

" 打开和关闭NERDTree快捷键
map <F10> :NERDTreeToggle<CR>
nmap <M-m> :NERDTreeFind<CR>

" 显示行号
let NERDTreeShowLineNumbers=1
" 打开文件时是否显示目录
let NERDTreeAutoCenter=0
" 是否显示隐藏文件
let NERDTreeShowHidden=0
" 设置宽度
" let NERDTreeWinSize=31
" 忽略一下文件的显示
let NERDTreeIgnore=['\.pyc','\~$','\.swp']
" 打开 vim 文件及显示书签列表
let NERDTreeShowBookmarks=2

" 在终端启动vim时,共享NERDTree
let g:nerdtree_tabs_open_on_console_startup=1

majutsushi/tagbar 插件:

nmap <F9> :TagbarToggle<CR>

let g:tagbar_type_go = {
			\ 'ctagstype' : 'go',
			\ 'kinds'     : [
			\ 'p:package',
			\ 'i:imports:1',
			\ 'c:constants',
			\ 'v:variables',
			\ 't:types',
			\ 'n:interfaces',
			\ 'w:fields',
			\ 'e:embedded',
			\ 'm:methods',
			\ 'r:constructor',
			\ 'f:functions'
			\ ],
			\ 'sro' : '.',
			\ 'kind2scope' : {
			\ 't' : 'ctype',
			\ 'n' : 'ntype'
			\ },
			\ 'scope2kind' : {
			\ 'ctype' : 't',
			\ 'ntype' : 'n'
			\ },
			\ 'ctagsbin'  : 'gotags',
			\ 'ctagsargs' : '-sort -silent'
			\ }

nerdtree-git-plugin 插件:

let g:NERDTreeIndicatorMapCustom = {
			\ "Modified"  : "✹",
			\ "Staged"    : "✚",
			\ "Untracked" : "✭",
			\ "Renamed"   : "➜",
			\ "Unmerged"  : "═",
			\ "Deleted"   : "✖",
			\ "Dirty"     : "✗",
			\ "Clean"     : "✔︎",
			\ 'Ignored'   : '☒',
			\ "Unknown"   : "?"
			\ }

let g:NERDTreeShowIgnoredStatus = 1
nmap <Leader>pwd :NERDTreeCWD<CR>

YouCompleteMe插件配置:

配置YouComplete,进入 ~/.vim/plugged/YouCompleteMe 目录下,使用 ./install.py –clang-completer –go-completer 命令进行build ycmd.so 动态库。对于其他语言的支持,可以参考YouCompleteMe的Github下的README 或者遇到错误请参考issue。这些工作做完之后配置.vimrc

" make YCM compatible with UltiSnips (using supertab)
let g:ycm_key_list_select_completion = ['<M-j>', '<DOWN>']
let g:ycm_key_list_previous_completion = ['<M-k>', '<Up>']
let g:SuperTabDefaultCompletionType = '<M-j>'

" 关闭了提示再次触发的快捷键
let g:ycm_key_invoke_completion = '<Leader>,'
let g:ycm_global_ycm_extra_conf = '~/.vim/plugged/youcompleteme/third_party/ycmd/.ycm_extra_conf.py’

若阁下需要添加自定义的header files,方便自动补全C++代码,可以更改~/.vim/plugged/YouCompleteMe/third_party/ycmd/.ycm_extra_conf.py 文件,将阁下想使用的库文件的include path加入其中即可。注意变更配置文件之后需要重启ycmd服务器,使用 :YcmRestartServer 重启即可,遇到不正常的错误信息,可以使用:YcmDebugInfo 进行查看。

还有一些其余配置:

let g:UltiSnipsExpandTrigger = "<tab>"
let g:UltiSnipsJumpForwardTrigger = "<tab>"
let g:UltiSnipsJumpBackwardTrigger = "<s-tab>"

"==============================================================================
"  其他插件配置
"==============================================================================

" markdwon 的快捷键
map <silent> <F5> <Plug>MarkdownPreview
map <silent> <F6> <Plug>StopMarkdownPreview

" tab 标签页切换快捷键
:nn <Leader>1 1gt
:nn <Leader>2 2gt
:nn <Leader>3 3gt
:nn <Leader>4 4gt
:nn <Leader>5 5gt
:nn <Leader>6 6gt
:nn <Leader>7 7gt
:nn <Leader>8 8gt
:nn <Leader>9 8gt
:nn <Leader>0 :tablast<CR>

:nn <M-1> 1gt
:nn <M-2> 2gt
:nn <M-3> 3gt
:nn <M-4> 4gt
:nn <M-5> 5gt
:nn <M-6> 6gt
:nn <M-7> 7gt
:nn <M-8> 8gt
:nn <M-9> 9gt
:nn <M-0> :tablast<CR>

" 自动注释的时候添加空格
let g:NERDSpaceDelims=1

" 有道词典插件
map <M-t> :Ydc<CR>

" 自动切换到当前文件所在的目录 cdpath
map <Leader>cd :cd %:h<CR>

" 退出
map <Leader>q :q<CR>
map <Leader>wq :wq<CR>

以Tab页作为打开文件的默认方式,如以下设置,可以使用<leader> + 数字键进行切换不同Tab页,Vim的默认leader键是 ‘\’

let NERDTreeMapOpenInTab='<ENTER>'

文件跳转:在Vim中,我们常常会用到跳转头文件的情景,我们需要将我们所需要的头文件加入到Vim的search path 中,然后将Vim的光标放到头文件所在处,使用gf(默认)就可以完成文件跳转。如果需要快速回到之前的文件可以使用 Ctrl+oCtrl+i可以前进到之前的文件。下面是我的例子(存在.vimrc中)

" MY PERSONAL VIM SEARCH PATH
set path+=/usr/local/include/activemq-cpp-3.10.0
set path+=/usr/local/boost_1_71_0/
set path+=/usr/local/opt/apr/libexec/include
set path+=/usr/local/include/c++/8.3.0
set path+=/usr/local/include/

当然你也可以临时使用命令生效 search path。 查看当前search path 可以使用:set path? 进行查看。临时加入一个search path可以这样操作 :set path+=/usr/local/include,.,

如果阁下的include path 特别多的但又不想设置到 .vimrc中的话,也可以参考此链接的设置,将path存放到.zshrc中,这样子再次启动vim的时候。path将会自动被加载。很是方便! 来自laixintao 同学的建议: https://github.com/laixintao/myrc/blob/442e936772901daf3d6b3daab241d2b55bd0542b/.zshrc#L189

Vim 美化,加入酷炫的图标。

# 在macOS上需要增加新的字体,并且将iTerm2的Profile中的字体设置成<strong>Hack NERD Font</strong>
brew tap homebrew/cask-fonts
brew cask install font-hack-nerd-font

# 配置完后 将 Plug 'ryanoasis/vim-devicons' 放到.vimrc 配置文件中,并使用PlugInstall 进行安装,注意需要设置编码  set encoding=UTF-8 

# 一切配置完毕之后,重新进入Vim 或者 :source .vimrc 即可

最后预览一下成品:

Vim-IDE demo

学习、使用Vim是一个循序渐进的过程,想要高效率地使用Vim肯定是需要投入一些时间,切勿浅尝辄止,希望此篇文章可以对阁下有所帮助!

参考文献:

  1. https://learnku.com/articles/24924
  2. https://github.com/ycm-core/YouCompleteMe
  3. https://github.com/junegunn/vim-plug
  4. https://vimjc.com/vim-goto-file.html
  5. https://github.com/ryanoasis/vim-devicons
  6. https://github.com/ryanoasis/nerd-fonts
  7. https://learnvimscriptthehardway.stevelosh.com/

Monitor ActiveMQ Queue and Topic Status

在最近的工作中,公司平台部门人员使用的JMS(Java Message Service)服务中经常出现拥塞的情况,项目的后台需要一个综合的监控程序实时监控ActiveMQ的服务状态,我这边实现了部分监控功能,在这边做一下工作的总结。

第一次尝试:ActiveMQ-CPP (Failed)

我一开始查询了很多资料,看到Apache ActiveMQ的官网有提到过ActiveMQ-CPP 这个项目,但是无奈现在的C++能力有点偏弱,加之Doxygen的文档看到想吐,就换了其他方案。改用调用ActiveMQ Web ConsoleXML 返回结果来提取我所需要的信息。

第二次尝试:Golang 调用Web Console

提取信息的过程非常成功,按照默认配置安装ActiveMQWeb admin 入口为 http://localhost:8161/admin 进入这个管理页面会有一层Basic Authentication,也就是需要在请求的Header里面加入{“Authorization”: ‘Basic *’} 注: “*” 代表 base64Encode(username + ‘:’ + password) 相信大家应该能够理解。我的设想是因为Go语言是可以将源代码编译成动态链接库的,编译的方式类似: go build -o gohttp.so -buildmode=c-shared gohttp.goCGO生成动态链接库和头文件是有前提的,必须要引入 C import "C"而且有个比较恶心的就是需要使用C中对应的类型所以后期维护起来还是很麻烦,且对于我们公司的代码管理不方便(公司的后端代码基本全是C++)。

第三次尝试:Restclient-CPP 成功

RestClient-CPP是基于libcurl二次封装的一个C++ HTTP库,使用起来很方便,项目可以在Github上找到。实现的主要思路就是登陆ActiveMQ Web Console 然后Queue Topic 对应信息的XML结果再用Qt的库对XML进行解析提取所需字段即可,具体参考代码如下:https://github.com/cyber-prog0x/CSnippets/blob/master/activemq_monitor.cpp