yishiyaonie:GO liuhanlin$ go version
go version go1.5.1 darwin/amd64
记住版本不能过低,比如1.2,在以后的编译项目过程中可能会带来很多很多麻烦。切记。
mkdir -p /Users/liuhanlin/GO
export GOPATH=/Users/liuhanlin/GO
export GOBIN=$GOPATH/bin
export PATH=$PATH:$GOBIN
加入如下环境变量控制,最后保存
source ~/.bash_profile
yishiyaonie:GO liuhanlin$ go env
GOARCH="amd64"
GOBIN="/Users/liuhanlin/GO/bin"
GOEXE=""
GOHOSTARCH="amd64"
GOHOSTOS="darwin"
GOOS="darwin"
GOPATH="/Users/liuhanlin/GO"
GORACE=""
GOROOT="/usr/local/go"
GOTOOLDIR="/usr/local/go/pkg/tool/darwin_amd64"
GO15VENDOREXPERIMENT=""
CC="clang"
GOGCCFLAGS="-fPIC -m64 -pthread -fno-caret-diagnostics -Qunused-arguments -fmessage-length=0 -fno-common"
CXX="clang++"
CGO_ENABLED="1"
gobin文件夹是用来存放go项目编译的二进制文件的
yishiyaonie:~ liuhanlin$ go get -u github.com/qor/qor-example
package golang.org/x/net/html: unrecognized import path "golang.org/x/net/html"
package golang.org/x/image/bmp: unrecognized import path "golang.org/x/image/bmp"
package golang.org/x/image/tiff: unrecognized import path "golang.org/x/image/tiff"
package golang.org/x/net/context: unrecognized import path "golang.org/x/net/context"
我们发现有几个依赖的库没有下载下来,导致go get 没能正常的build编译。
解决方法有三种
1,翻墙,直到能够下载golang.org/x下的文件位置,建议不采用,因为我尝试过各种方式。
2,去gopm上去下载,手动下载的是zip包,但是在编译的时候会报错误,具体错误应该是跟git有关的。
3,最简单,最快捷的方式就是直接到git上面去git clone。接下来采用git clone的方式。
mkdir -p golang.org/x/
cd /Users/liuhanlin/GO/src/golang.org/x
git clone https://github.com/golang/net.git
git clone https://github.com/golang/image.git
go get -u github.com/qor/qor-example
yishiyaonie:GO liuhanlin$ ls
bin pkg src
我们看到go get 在下载包的同时,也编译了文件,但是此时的文件是有问题的,当真正运行的时候是有错误的。可能就是所谓的动态编译何静态编译的问题吧。
登录云主机
liuhanlin$ ssh -i ~/.ssh/vm1-ssh-key root@ip
登录mysql
mysql -u root -p
输入:
GRANT ALL ON *.* TO username@'%' IDENTIFIED BY 'password' WITH GRANT OPTION;
退出
vi /etc/mysql/my.cnf
bind-address = 127.0.0.1
改为:
bind-address = 0.0.0.0
sudo /etc/init.d/mysql restart
然后访问下
mysql -h ip -u root -p
如果成功代表ok
liuhanlin$ cd $GOPATH/src/github.com/qor/qor-example
liuhanlin$ go run main.go
Failed to find configuration config/database.yml, using example file config/database.example.yml
panic: dial tcp 127.0.0.1:3306: getsockopt: connection refused
goroutine 1 [running]:
github.com/qor/qor-example/db.init.1()
/Users/liuhanlin/GO/src/github.com/qor/qor-example/db/db.go:44 +0x4c1
github.com/qor/qor-example/db.init()
/Users/liuhanlin/GO/src/github.com/qor/qor-example/db/db.go:46 +0x6d
github.com/qor/qor-example/app/models.init()
/Users/liuhanlin/GO/src/github.com/qor/qor-example/app/models/user.go:21 +0x74
github.com/qor/qor-example/config/admin.init()
/Users/liuhanlin/GO/src/github.com/qor/qor-example/config/admin/worker.go:133 +0x6c
main.init()
/Users/liuhanlin/GO/src/github.com/qor/qor-example/main.go:29 +0x4a
goroutine 17 [syscall, locked to thread]:
runtime.goexit()
/usr/local/go/src/runtime/asm_amd64.s:1696 +0x1
goroutine 20 [chan receive]:
database/sql.(*DB).connectionOpener(0xc820282f00)
/usr/local/go/src/database/sql/sql.go:634 +0x45
created by database/sql.Open
/usr/local/go/src/database/sql/sql.go:481 +0x336
exit status 2
哇,报错了。很显然啊,这是数据库的链接报错,或许是因为密码不对,或者数据库不存在,或者数据库网络不通都有可能。所以接下来。
yishiyaonie:qor-example liuhanlin$ vi config/database.example.yml
加入访问密码
yishiyaonie:qor-example liuhanlin$ cat config/database.example.yml
db:
adapter: mysql
name: qor_example
user: root
password: 。。。
fmt.Sprintf("%v:%v@tcp(ip:3306)/%v", dbConfig.User, dbConfig.Password, dbConfig.Name))
yishiyaonie:qor-example liuhanlin$ go run main.go
Failed to find configuration config/database.yml, using example file config/database.example.yml
[info] replacing callback `gorm:delete` from /Users/liuhanlin/GO/src/github.com/qor/publish/publish.go:144
Failed to create unique index for translations key & locale, got: Error 1170: BLOB/TEXT column 'key' used in key specification without a key length
(Error 1170: BLOB/TEXT column 'key' used in key specification without a key length)
[2016-05-29 18:00:07]
[GIN-debug] [WARNING] Running in "debug" mode. Switch to "release" mode in production.
- using env: export GIN_MODE=release
- using code: gin.SetMode(gin.ReleaseMode)
[GIN-debug] GET / --> github.com/qor/qor-example/app/controllers.HomeIndex (3 handlers)
[GIN-debug] GET /products/:code --> github.com/qor/qor-example/app/controllers.ProductShow (3 handlers)
Listening on: 7000
[GIN] 2016/05/29 - 18:00:48 | 200 | 282.869157ms | ::1 | GET /
http://localhost:7000/admin
ok,花了周末两天时间学了好多东西,希望能帮到同样需要帮助的人。