详述 iTerm2 配色及免密登录 SSH 的方法

博主说:iTerm2 是一个 Mac 版的类似于 Xshell 的终端工具,虽然很多同学说其功能并没有 Xshell 那么强大,但它仍然能够满足我们的大部分需求了。在此文中,我们将详细介绍 iTerm2 的配色方案及免密登录 SSH 的方法。

首先,给出 iTerm2 的相关链接,

接下来,进入本文的正题。

Section 1:iTerm2 的配色方法

自定义 iTerm2 的配色,具体步骤如下:

1. 设置终端和ls可配色

登录 Mac 终端,输入vim ~/.bash_profile,即用 vim 文本编辑器打开bash_profile文件,然后添加如下内容,

#enables colorin the terminal bash shell export
export CLICOLOR=1

#setsup thecolor scheme for list export
export LSCOLORS=gxfxcxdxbxegedabagacad

#sets up theprompt color (currently a green similar to linux terminal)
export PS1='\[\033[01;32m\]\u@\h\[\033[00m\]:\[\033[01;36m\]\w\[\033[00m\]\$'
#enables colorfor iTerm
export TERM=xterm-256color

2. 设置 vim 可配色

终端输入vim .vimrc,设置内容如下,

syntax on
set number
set ruler

截止到此步骤,我们就会发现,终端及 vim 的颜色已经修改完成了。接下来,配置 iTerm2 颜色主题。

3. 配置 iTerm2 颜色主题

先进入「iTerm2 客户端颜色主题」下载 iTerm2 主题,

如上图所示,点击红色标记处,下载 iTerm2 主题,然后依次选择iTerm2 -> Preferences -> Profiles -> Colors -> import

点击import之后,选择我们想要的主题,由于 iTerm2 提供的主题超过 150 多种,我们就不一一介绍了,在此以 Solarized Dark Higher Contrast 主题为例进行演示,

在 iTerm2 的颜色主题导入成功之后,我们需要手动勾选,使其生效,

在我们勾选Solarized Dark Higher Contrast主题之后,其效果如下图所示:

至此, iTerm2 的颜色主题配置完成。

Section 2:iTerm2 免密登录 SSH 的方法

现在,我们来实现 iTerm2 免密登录 SSH,具体步骤如下:

1. 创建expect脚本

在 Mac 终端或者 iTerm2 中,输入vim iterm2login.sh,创建名为iterm2login的脚本,内容为

#!/usr/bin/expect

set timeout 30
spawn ssh -p [lindex $argv 0] [lindex $argv 1]@[lindex $argv 2]
expect {
        "(yes/no)?"
        {send "yes\n";exp_continue}
        "password:"
        {send "[lindex $argv 3]\n"}
}
interact

如上面的代码所示,其含有四个参数,分别为

  • [lindex $argv 0],表示服务器端口号;
  • [lindex $argv 1],表示服务器名称;
  • [lindex $argv 2],表示服务器 IP 地址;
  • [lindex $argv 3] ,表示服务器密码。

在这里,Shell 文件是用expect命令书写的脚本,其可以自动和网络进行交互,基本原理就是先解析 SSH 的命令,然后在根据文本内容进行匹配,执行对应的操作,send则是模拟人工输入的过程。

2. 在 iTerm2 中配置新的Profile

在这里,我们依次选择iTerm2 -> Preferences -> Profiles,进入如下界面:

  • 标注 1+表示新增Profile-表示移除Profile
  • 标注 2:表示我们自定义的Profile名称,并显示在 标注 3 处;
  • 标注 3Profile Name,显示所有的Profile列表;
  • 标注 4Send text at start,发送服务器相关信息至expect脚本。

其中,标注 4 的内容是非常重要的,其必须按顺序包括:expect脚本的全路径、端口号、服务器名称及服务器密码。如果 标注 4 的内容书写错误或者弄混顺序,则必然导致 SSH 免密登录失败。此外,服务器默认端口为22,具体按实际情况而定。在此给出一个 标注 4 的内容实例,

  • /Users/bin.guo/Documents/RESOURCES/iterm2login.sh 22 guest 10.11.12.13 password

其中,

  • /Users/bin.guo/Documents/RESOURCES/iterm2login.sh,表示expect脚本的全路径;
  • 22,表示服务器端口号;
  • guest,表示服务器名称;
  • 10.11.12.13,表示服务器地址;
  • password,表示服务器密码。

如上图所示,通过此选项,即可免密登录服务器。至此,iTerm2 免密登录 SSH 设置完成。

参考文献: [1] ITerm2配色方案. [2] iterm2如何不用每次输入密码登录ssh.

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏散尽浮华

Nginx反向代理+负载均衡简单实现(https方式)

背景: A服务器(192.168.1.8)作为nginx代理服务器 B服务器(192.168.1.150)作为后端真实服务器 现在需要访问https://tes...

69980
来自专栏静下来

wordpress您的主机禁用了mail()函数 SMTP邮件通知解决方法

image.png 由于国家规定今后论坛啥的发帖得实名,所以我服务器测评的网站就关闭了评论,仅注册了用户才能评论。 然后看了下wordpress默认的邮件是没用...

92370
来自专栏醉梦轩

NGINX部署HTTPS

1.7K50
来自专栏签桶

RFC 7519 JWT介绍

服务端要存储登陆状态,这对单机模式没什么用影响,对于集群模式是很大的挑战,为了方便横向扩展,要把这些登陆态拆出来,常见的做法是写入redis集群和持久化sess...

28900
来自专栏我的小碗汤

浅谈json web token及应用

Json Web Token (JWT),是一个非常轻巧的规范,这个规范允许在网络应用环境间客户端和服务器间较安全的传递信息。该token被设计为紧凑且安全的,...

13130
来自专栏FreeBuf

linux下利用一次性口令实现安全管理

作者 黑狐 [译自vpsboard] Linux服务器一直就是以稳定、高效、安全而著称。安全是比较重要的一个环节,这关系到商业机密,更关系到企业的存亡。本文...

27870
来自专栏FH云彩

免费的泛域名SSL证书!

1K40
来自专栏葡萄城控件技术团队

网站HTTP升级HTTPS完全配置手册

今天,所有使用Google Chrome稳定版的用户迎来了v68正式版首个版本的发布,详细版本号为v68.0.3440.75,上一个正式版v67.0.3396....

47000
来自专栏腾讯云API

腾讯云 API 最佳实践:保护你的密钥

使用腾讯云 API 时,你需要用密钥来签名你的 API 请求。腾讯云接收到你的请求后,会比对你的签名串和实际请求参数。

8.7K110
来自专栏醉梦轩

NGINX部署HTTPS

nginx是一款高性能的Web服务器,可以用作反向代理和负载均衡。随着HTTPS的不断推进,越来越多的网站都开始转到HTTPS方式,HTTP仅仅作为重定向到HT...

39930

扫码关注云+社区

领取腾讯云代金券