Mr.Miaow Blog

Do what you say, say what you do.

HTTP(HyperText Transfer Protocol 超文本传输协议)是互联网上应用最为广泛的一种网络协议,它是由万维网协会(World Wide Web Consortium)制定发布。

文章主要以一次HTTP请求的整个过程来讲解(DNS解析不讲):HTTP 起源、TCP/IP 协议、建立 TCP 连接、客户端请求、服务端响应、断开 TCP 连接,文章最后还捎带讲了与 HTTP 相关知识。

阅读全文 »

1. 简介

lighttpd 提供了一种外部程序调用的接口,即 FastCGI 接口。这是一种独立于平台和服务器的接口,它介于Web应用程序和Web服务器之间。

这就意味着能够在 Apache 服务器上运行的 FastCGI 程序,也一定可以无缝的在 lighttpd 上使用。

阅读全文 »

1. 确定安装的lighttpd支持ssl

版本信息中含有(ssl)字样的信息说明支持ssl,可以在终端输入如下查看:

1
2
3
$ lighttpd -v
lighttpd/1.4.35 (ssl) - a light and fast webserver
Build-Date: Apr 25 2017 10:25:18
阅读全文 »

1. 检出

1
2
3
4
5
6
$ svn  checkout  http://路径(目录或文件的全路径) [本地目录全路径] --username 用户名
$ svn checkout svn://路径(目录或文件的全路径) [本地目录全路径] --username 用户名
# 也可以使用缩写
# 例子:
$ svn co svn://localhost/测试工具 /home/testtools --username wzhnsc
$ svn co http://localhost/test/testapp --username wzhnsc
阅读全文 »

原文链接

主体的思路是将博文内容相关文件放在Github项目中master中,将Hexo配置写博客用的相关文件放在Github项目的hexo分支上,这个是关键,多终端的同步只需要对分支hexo进行操作。下面是详细的步骤讲解:

阅读全文 »

【Git】子模块:一个仓库包含另一个仓库

如何在大型项目中使用Git子模块开发

git子模块

到目前为止,将您的大项目分解为子项目.
现在使用以下命令将每个子项目添加到主项目:

1
$ git submodule add <url>

项目添加到您的仓库后,您必须初始化并更新它.

1
2
$ git submodule init
$ git submodule update

从Git 1.8.2开始,新选项 –remote 被添加

1
$ git submodule update --remote --merge

将从每个子模块的上游获取最新的更改,将它们合并,并检查子模块的最新版本.

1. 使用场景

基于公司的项目会越来越多,常常需要提取一个公共的类库提供给多个项目使用,但是这个library怎么和git在一起方便管理呢?

我们需要解决下面几个问题:

  • 如何在git项目中导入library库?
  • library库在其他的项目中被修改了可以更新到远程的代码库中?
  • 其他项目如何获取到library库最新的提交?
  • 如何在clone的时候能够自动导入library库?

解决以上问题,可以考虑使用git的 Submodule来解决。

2. 什么是Submodule?

git Submodule 是一个很好的多项目使用共同类库的工具,他允许类库项目做为repository,子项目做为一个单独的git项目存在父项目中,子项目可以有自己的独立的commitpushpull。而父项目以Submodule的形式包含子项目,父项目可以指定子项目header,父项目中会的提交信息包含Submodule的信息,再clone父项目的时候可以把Submodule初始化。

3. 在项目中使用Submodule

使用git命令可以直接添加Submodule

1
$ git submodule add git@github.com:xxx.git pod-library

使用 git status命令可以看到

1
$ git status
1
2
3
4
5
On branch master
Changes to be committed:

new file: .gitmodules
new file: pod-library

可以看到多了两个需要提交的文件:.gitmodulespod-library

.gitmodules 内容包含Submodule的主要信息,指定reposirory,指定路径:

1
2
3
[submodule "pod-library"]
path = pod-library
url = git@github.com:xxx/pod-library.git

可以看到记录了子项目的目录和子项目的git地址信息。

pod-libray内容只保护子项目的commit id,就能指定到对于的git header上,例如:

1
Subproject commit 4ac42d2f8b9ba0c2f0f2f2ec87ddbd529275fea5

4ac42d2f8b9ba0c2f0f2f2ec87ddbd529275fea5就是子项目的commit id,父项目的git并不会记录Submodule的文件变动,它是按照commit git指定Submodulegit header

另外,这两个文件都需要提交到父项目的git中

还可以这样使用命令添加Submodule

1
2
3
$ git add .gitmodules pod-ibrary
$ git commit -m "pod-library submodule"
$ git submodule init

4. 修改Submodule

首先需要确认有对Submodule的commit权限

进入Submodule目录里面:

1
$ cd pod-library/

修改其中的一个文件看下文件的可以用git status查看变动:

1
2
$ git status
modified: pod-library/UseAFHTTP.h

提交Submodule的更改内容:

1
$ git commit -a -m'test submodule'

然后push 到远程服务器:

1
$ git push

然后再回到父目录,提交Submodule在父项目中的变动:

1
2
3
4
$ cd ..
$ git status
on branch master
modified: pod-library (new commits)

可以看到pod-library中已经变更为Submodule最新的commit id:

1
Subproject commit 330417cf3fc1d2c42092b20506b0d296d90d0b5f

需要把Submodule的变动信息推送到父项目的远程服务器

1
2
$ git commit -m'update submodule'
$ git push

这样就把子模块的变更信息以及子模块的变更信息提交到远程服务器了,从远程服务器上更新下来的内容就是最新提交的内容了。

5. 更新Submodule

更新Submodule有两种方式:

在父项目的目录下直接运行

1
$ git submodule foreach git pull

在Submodule的目录下面更新

1
2
$ cd pod-library
$ git pull

可以看到在Submodule的目录中,使用git和单独的一个项目是一样的,注意更新Submodule的时候如果有新的commit id产生,需要在父项目产生一个新的提交,pod-libray文件中的 Subproject commit会变为最新的commit id

6. clone Submodule

clone Submodule有两种方式 一种是采用递归的方式clone整个项目,一种是clone父项目,再更新子项目。

  1. 采用递归参数 --recursive
1
$ git clone git@github.com:xxx.git --recursive

输出结果:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
loning into 'pod-project'...
remote: Counting objects: 57, done.
remote: Compressing objects: 100% (45/45), done.
remote: Total 57 (delta 13), reused 49 (delta 8), pack-reused 0
Receiving objects: 100% (57/57), 18.79 KiB | 0 bytes/s, done.
Resolving deltas: 100% (13/13), done.
Checking connectivity... done.
Submodule 'pod-library' (git@github.com:xxx.git) registered for path 'pod-library'
Cloning into 'pod-library'...
remote: Counting objects: 34, done.
remote: Compressing objects: 100% (25/25), done.
remote: Total 34 (delta 8), reused 30 (delta 7), pack-reused 0
Receiving objects: 100% (34/34), 12.95 KiB | 0 bytes/s, done.
Resolving deltas: 100% (8/8), done.
Checking connectivity... done.
Submodule path 'pod-library': checked out '330417cf3fc1d2c

42092b20506b0d296d90d0b5f'

可以看到init Submodule 会自动被clone下来

  1. 第二种方法先clone父项目,再初始化Submodule
1
2
3
$ git clone git@github.com:xxx/pod-project.git
$ cd pod-project
$ git submodule init

输出:

1
2
Submodule 'pod-library' (git@github.com:xxx/pod-library.git) 
registered for path 'pod-library'

更新Submodule:

1
$ git submodule update

运行结果:

1
2
3
4
5
6
7
8
Cloning into 'pod-library'...
remote: Counting objects: 34, done.
remote: Compressing objects: 100% (25/25), done.
remote: Total 34 (delta 8), reused 30 (delta 7), pack-reused 0
Receiving objects: 100% (34/34), 12.95 KiB | 0 bytes/s, done.
Resolving deltas: 100% (8/8), done.
Checking connectivity... done.
Submodule path 'pod-library': checked out '330417cf3fc1d2c42092b20506b0d296d90d0b5f'

7. 删除Submodule

git 并不支持直接删除Submodule需要手动删除对应的文件:

1
2
3
4
$ cd pod-project
$ git rm --cached pod-library
$ rm -rf pod-library
$ rm .gitmodules

更改git的配置文件config:

1
$ vim .git/config

可以看到Submodule的配置信息:

1
2
[submodule "pod-library"]
url = git@github.com:xxx/pod-library.git

删除submodule相关的内容,然后提交到远程服务器:

1
$ git commit -a -m 'remove pod-library submodule'

我每天使用 Git ,但是很多命令记不住。

一般来说,日常使用只要记住下图6个命令,就可以了。但是熟练使用,恐怕要记住60~100个命令。

阅读全文 »