搭建bower私服(private-bower)

操做系统:Linux VM_71_121_centos 2.6.32-431.el6.x86_64 #1 SMP Fri Nov 22 03:15:09 UTC 2013 x86_64 x86_64 x86_64 GNU/Linuxnode

搭建私服所需工具清单:c++

1nodejsgit

2gitnpm

3gitosisjson

4private-bowerwindows

1、安装 nodejscentos

Centos 安装 NodeJS缓存

准备命令:bash

默认没有编译环境。须要安装的组件有gcc,make,gcc-c++,openssl-devel以及wget服务器

yum -y install gcc make gcc-c++ openssl-devel wget

下载源码及解压:

wget http://nodejs.org/dist/v0.10.26/node-v0.10.26.tar.gz

tar -zvxf node-v0.10.26.tar.gz

编译及安装:

cd node-v0.10.26

make && make install

验证是否安装配置成功:

node -v

 

 

2、安装 git

1、源码安装

下载git源码并解压缩

wget https://Github.com/Git/Git/archive/v2.3.0.tar.gz

tar -zxvf git-v2.3.0.tar.gz && cd git-2.3.0

make && make install

 

Git 的工做须要调用 curl,zlib,openssl,expat,libiconv 等库的代码,若是安装报错,请执行:

$ yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel 

若是执行上述命令,编译安装仍提示:Can't locate ExtUtils/MakeMaker.pm in @INC ,请执行:

yum install perl-devel 来解决该问题。

 

mkdir myBower/testBower -p 建立测试目录

 

添加 git 用户:adduser git,使用 git init first.git 命令初始化 git 仓库,并分配权限,chown -R git:git first.git

建议使用 git init --bare first.git 命令初始化 git 仓库,二者的区别以下:

通常我的使用,用git init,这时候你的工做区也在这里。你要是想创建一个固定的地址让你们一块儿用,就在服务器上用git --bare init

 

客户端测试可否下载:

执行命令:git clone ssh://git@115.159.31.188:/myBower/testBower/first.git

 

若是直接使用 git init first.git 在后续可能会出现以下问题:

git 提交时出现  refusing to update checked out branch: refs/heads/master 错误时,请在服务器上使用以下命令修复:

git config --bool core.bare true

 

git 提交时出现 warning: LF will be replaced by CRLF 错误时,请使用以下命令修复:

git config core.autocrlf true

错误缘由以下:

Windows上是CRLF来做为一行的结束符,而Linux上则是LF做为行结束符

git中提供了autocrlf的设置,能够用来自动转换CRLF,它能够设置成true,false,inpu

Windows上的msysgit默认设置了autocrlftrue

这样,在提交时自动地把行结束符CRLF转换成LF,而在签出代码时把LF转换成CRLF

这样保证了从windows平台上提交的代码,都是以LF做为行结束符

 

 

若是客户端下载工程的时候提示:

C:\Users\User\Desktop\新建文件夹 (3)>git clone ssh://git@115.159.31.188:/myBower/t

estBower/first.git

Cloning into 'first'...

git@115.159.31.188's password:

bash: git-upload-pack: command not found

fatal: Could not read from remote repository.

请执行相似:ln /root/bin/git* /usr/bin//root/bingit安装以后所在的目录

 

C:\Users\User\Desktop\新建文件夹 (3)>git clone ssh://git@115.159.31.188:/myBower/t

estBower/first.git

Cloning into 'first'...

git@115.159.31.188's password:

fatal: unable to access '/root/etc/gitconfig': Permission denied

fatal: Could not read from remote repository.

该问题暂未处理

 

2、直接安装 git

因为采用方法一中的源码安装,客户端在下载时会提示

fatal: unable to access '/root/etc/gitconfig': Permission denied

fatal: Could not read from remote repository.

而采用直接安装则无此问题,所以推荐直接安装。

直接安装命令为:yum install git

 

3、安装 gitosis

 

请参考

https://git-scm.com/book/zh/v1/%E6%9C%8D%E5%8A%A1%E5%99%A8%E4%B8%8A%E7%9A%84-Git-Gitosis

安装 gitosis ,使 git 服务器支持 git 协议。

 

4、安装 private-bower

使用 npm install private-bower -g 命令安装private-bower,建立配置文件,如:myBowerConfig.json,该文件内容以下:

{

    "port": 81,

    "registryFile": "",

    "timeout": 144000,

    "public": {

        "disabled": false,

        "registry": "http://115.159.31.188/packages/",

        "registryFile": "",

        "whitelist": [],

        "blacklist": []

    },

    "authentication": {

        "enabled": false,

        "key": "password"

    },

    "repositoryCache": {

        "cachePrivate": false,

        "git": {

            "enabled": false,

            "cacheDirectory": "./gitRepoCache",

            "host": "localhost",

            "port": 6789,

            "publicAccessURL" : null,

            "refreshTimeout": 10

        },

        "svn": {

            "enabled": false,

            "cacheDirectory": "./svnRepoCache",

            "host": "localhost",

            "port": 7891,

            "publicAccessURL" : null,

            "refreshTimeout": 10

        }

    },

    "proxySettings" : {

        "enabled": false,

        "host": "proxy",

        "username": "name",

        "password" : "pass",

        "port": 8080,

        "tunnel": false

    },

    "log4js" : {

        "enabled": false,

        "configPath" : "log4js.conf.json"

    }

}

请将 "registry": "http://115.159.31.188/packages/" 条目中的地址修改成本身服务器的地址。

 

5、服务器端启动 bower 注册服务

使用 private-bower --config /myBower/bowerServer/myBowerConfig.json 命令启动bower 注册服务

 

6、注册bower包到服务器

1建立 .bowerrc 文件,文件内容以下:

{

"registry": "http://115.159.31.188:81"

}

2、注册包到服务器,执行:bower register wx001 git@115.159.31.188:/myBower/testBower/first.git

 

7、安装服务器已注册的bower

 

1建立 .bowerrc 文件,文件内容以下:

{

"registry": "http://115.159.31.188:81"

}

2、使用 bower install wx001 命令安装包到当前目录

 

至此,bower 私服搭建已完成。

 

8、private-bower 做为后台服务运行的方法

nohup private-bower --config myBowerConfig.json &

关闭进程的方法:

ps -ef | grep private-bower 查看进程号

kill <进程号> 执行关闭操做,参数 -9 强行终止

 

8、常见问题

1bower 安装安装时,出现地址解析错误

解决方法:bower cache clean 清理缓存

2private-bower 启动后提示“ssh链接时提示“The authenticity of host xx can’t be established”

解决方法:

a. 使用ssh链接远程主机时加上“-o StrictHostKeyChecking=no”的选项,以下:

ssh  -o StrictHostKeyChecking=no  192.168.xxx.xxx

b. 一个完全去掉这个提示的方法是,修改/etc/ssh/ssh_config文件(或$HOME/.ssh/config)中的配置,添加以下两行配置:

StrictHostKeyChecking no

UserKnownHostsFile /dev/null

修改好配置后,从新启动sshd服务便可,命令为:/etc/init.d/sshd restart (或 service sshd restart

相关文章
相关标签/搜索