RVM 简易使用教程

Python012

RVM 简易使用教程,第1张

虽然可以用 sudo 命令将 rvm 安装到 /usr/local 目录下,但官方推荐的还是单用户安装,命令是:

默认安装会修改 dotfiles 比如 ~/.bash_profile ,如果不想要修改 dotfiles,则执行如下命令:

如果要执行多用户安装,将 rvm 安装到 /usr/local 里,则执行:

安装完成后,请执行以下命令检查是否成功:

如果提示 rvm is a function 就表示成功,否则需要 source ~/.bash_profile ,如果你想我一样用的是一个非 login shell,比如 mate-terminal, 这时候需要编辑 ~/.bash_profile ,将其中的这一行剪切复制到 ~/.bahrc 中:

如果想要把系统自带的 Ruby 加载进来,可以执行如下的命令:

首先可以列出所有一直版本的 Ruby,命令是:

安装特定版本的 Ruby 用 rvm install [版本号] ,然后用 rvm use [版本号] 来切换版本,比如安装 2.1.1 :

这会把 ruby 安装到 ~/.rvm/rubies/ruby-[版本号] 目录下,你还可以设置默认的 ruby ,这会覆盖系统本身的 ruby,命令是:

查询已经安装的 ruby 版本的命令是:

卸载一个已经安装的版本的命令是:

rvm 让 ruby、gems 和 irb 都组件化,并相互独立。gemset 可以理解为是一个独立的虚拟 Gem 环境,每一个 gemset 都是相互独立的。gemset 是附加在特定的 ruby 版本上的,例如用了 1.9.2, 建立了一个叫 rails3 的 gemset,当切换到 1.8.7 的时候,rails3 这个 gemset 并不存在。

命令是:

首先需要切换到 ruby版本号@gemset名 ,然后再用 gem install 来安装,例如:

用 use 命令就可以实现,比如:

停止使用自定义的 gemset ,返回到默认的 gemset ,可以用以下两个命令中的一个:

命令是:

命令是:

命令是:

命令是:

在项目中,比如 rails ,可以在目录下建立 .rvmrc 文件来指定自动使用的 gemset,内容可以是:

执行下面的命令会彻底删除 .rvm 目录,从而删除 rvm:

在我使用的 archlinux 中,由于 openssl 已经升级到 1.1 版本,而 ruby 2.4之前用的版本依然是 openssl 1.0 ,因此 rvm install 会报错,此时需要在本地编译安装 openssl 1.0,然后再安装 ruby,命令是:

你根本没有进入ruby控制台,ruby要先运行ruby指令才进入ruby环境。

$,这是书本上表示的命令提示符。你要看一下书本上的前言或者第一章,一般书本在最开始会说明一下符号,字体格式代表的含义,你没有从头看起,漏掉了重要的提示信息。书本开头肯定告诉你$,表示命令提示符,这个字符不需要你输入的。

cd testsass已经成功了,你又用cd ..返回了,这是不对的。

touch style.css,要单独输入的,不要和cd命令混在一块。

你连基本的命令行概念都没有搞懂。

$是Linux的提示符,你用了Windows,估计后面很多问题,因为书本是以Linux为目标系统个来写的。

本文在Windows7下测试成功。

安装和设置Git

下载Git for

Windows,采用默认安装,安装完成后就可以在本地使用Git了。

但要将内容放到Github上,必须先在Github网站上注册个账户,然后在本机使用Git创建SSH Key。操作如下:

在Git Bash上输入命令:

ssh-keygen -C "[email protected]" -t rsa

Note: “[email protected]”需要更换成你在Github上注册的Email地址或者是Username

这样会在用户目录(C:\Users\用户名)下产生一个.ssh文件夹,里面为对应的SSH

Keys,其中id_rsa.pub是Github需要的SSH公钥文件。

到c:\Users\用户名\.ssh\目录找到id_rsa.pub(可能位置不一定对,但是确认是以.pub结尾的文件),并用记事本打开复制全部内容。

Note:建议私钥公钥的名称最好写成"id_rsa",这样连接Github的时候会找这个文件,如果文件名已定,之后改名也行。

在github网站选择“Account Settings”>>“SSH Public Keys”>>“Add another

public key”,将刚才复制的内容粘贴到key文本框内。

这样就可以直接使用Git和GitHub了。

Note:建议在Git Bash中输入“ssh -v [email protected]”测试能够正常连接github

安装Ruby环境

下载RubyInstaller和DevKit。

因为Octopress需要的Ruby版本为1.9.2,所以选rubyinstaller-1.9.2-p290.exe,DevKit-tdm-32-4.5.2-20111229-1559-sfx.exe。

先安装RubyInstaller,然后解压缩DevKit(路径中不能有中文)。

在“Start Command Prompt with Ruby”命令行中进入DevKit解压缩的目录,然后运行以下命令:

ruby dk.rb init

ruby dk.rb install

gem install rdiscount --platform=ruby

如果安装成功,就可以使用一些Ruby的工具了,也为后面搭建博客提供了基础环境。

安装Octopress

先通过Git从Github上克隆一份Octopress(在Git Bash上输入命令)

git clone git://github.com/imathis/octopress.git octopress

然后安装一些依赖的工具(后面都是在Start Command Prompt with Ruby中输入)

cd octopress

ruby --version # Should report Ruby 1.9.2

gem install bundler

bundle install

安装Octopress默认的Theme

rake install

配置Octopress

将octopress的文件夹下的_config.yml的编码改成UTF-8:

保存(或另存为)时选择编码格式为UTF-8

修改_config.yml,批改url、title、subtitle、author等等。

到Ruby的安装目次\lib\ruby\gems\1.9.1\gems\jekyll-0.11.2\lib\jekyll\找到convertible.rb这个文件,批改self.content

= File.read(File.join(base, name))为self.content = File.read(File.join(base,

name), :encoding =>"utf-8")。

写博文

最简单的方式:复制octopress\source\_posts下某个文件,例如2012-07-30-the-first-post.markdown,修改文件名和文件中的内容

或者,命令行中输入rake

new_post["title"],会创建一个新的Post,新文件在source/_post下,文件名如下面的格式:2012-07-31-title.markdown。该文件可以直接打开修改。

写文章时,可以使用Markdown和Octopress

Plugins等工具对内容进行格式排版。

预览效果

在修改设置或者写完文章后,想看看具体效果,可以通过如下命令来完成:

rake generate

rake preview

将博客部署到Github上

在预览的效果符合自己的预期后,就可以通过如下命令将内容部署到Github上了。

如果是第一次部署,需要在Github上创建一个username.github.com的repository

在github网站选择“Create a New Repo”,如图

填写对应的内容即可

note:Repository

name填写username.github.com,username一定要和github的username一致,建好的博客代表的是你这个github账户的主页即page

配置octopress与github的连接:

进入Octopress目录:

rake setup_github_pages

按照提示填入你的github项目网址,比如:

[email protected]:Username/yourname.github.com.git

note:可以按照上面的修改,也可以在github的项目页中找地址

分发到github上:

rake deploy

第一次运行时,会询问是否建立对github的授权,输入:yes。然后将站点更新的内容推送到github上。

补充一点:

最后的但并不是最重要的,我们需要将修改的日志同步到github上,因此下面的3个命令也是必须的。

git status

git add .

git commit -m 'your message'

git push origin source

大功告成!