zoukankan      html  css  js  c++  java
  • [inner] bug

    这样正确
    command: ["sh", "-c", "mysql -h${DC_DB_HOST} -uroot -p${MYSQL_ROOT_PASSWORD} ${MYSQL_DATABASE} < ./db/sql/latest_dump.sql"]
    
    这样错误
    command: ["mysql -h${DC_DB_HOST} -uroot -p${MYSQL_ROOT_PASSWORD} ${MYSQL_DATABASE} < ./db/sql/latest_dump.sql"]
    
    这样也错误
    command: "mysql -h${DC_DB_HOST} -uroot -p${MYSQL_ROOT_PASSWORD} ${MYSQL_DATABASE} < ./db/sql/latest_dump.sql"

    makefile:

    first step you should build a file name xxx.sh

    and then you should make it can execute use command "chomd +x xxx.sh"

    reference: http://tsov.net/sh-script-syntax/

    rsync:

    local to remote :       

    rsync -avz ./db root@xxxx:/root/

    and then it will create a dirctory like /root/db

    and -a means recur send document

    and -v means show in detils

    and -z means zip it to transport

    --------------

    remote to local

    rsync -avz root@xxxx:/root/db .

    and it will auto craete dictory in local like ./db

    pay attion:

    if you have a local file name xxx.sh and remote didn`t, it nothing happend

    if you have a local file name xxx.sh and remote also but their different.   

      1、remote to local and then the local file will replace by the remote file

          2、local to remove and then the remote file will replace by the local file 

    referencehttp://man.linuxde.net/rsync

    Dockerfile

    * if you use ./server/main to start the server and then your .gtml file shoule put on the database-work dirctory beause that is the 相对目录

    也就是相对目录是相对于你运行的路径????有待验证

    and then the dockerfile must use ./

    FROM golang:1.9.3-alpine3.7
    
    COPY . $GOPATH/src/database-work
    
    WORKDIR $GOPATH/src/database-work/server
    
    RUN go build -o main main.go
    
    ENTRYPOINT ["./main"]
    
    # must use ./main
    View Code

    一般你的dockerfile会这样写,需要写上workdir,但是由于你的.go往往会有"github.com/xxx/xxx"

    所以被迫你的dockerfile的workdir也就是你现在工程的workdir了

    shell file

    * in the first letter can not get space

    #!/bin/bash
    
    不能有空格,在#和!中
    View Code

    golang -- flag

    每一个flag只能解析一次,res := flag.String("onlyone", default_value, dafault_use)

    然后用go run main.go -onlyone 5是可以的

    go run main.go --onlyone 5也是可以的

    如果是bool,直接go run main.go -boolvalue就可以认为是true

    word && wordint不冲突,都可以用

    // [_Command-line flags_](http://en.wikipedia.org/wiki/Command-line_interface#Command-line_option)
    // are a common way to specify options for command-line
    // programs. For example, in `wc -l` the `-l` is a
    // command-line flag.
    
    package main
    
    // Go provides a `flag` package supporting basic
    // command-line flag parsing. We'll use this package to
    // implement our example command-line program.
    import "flag"
    import "fmt"
    
    func main() {
    
        // Basic flag declarations are available for string,
        // integer, and boolean options. Here we declare a
        // string flag `word` with a default value `"foo"`
        // and a short description. This `flag.String` function
        // returns a string pointer (not a string value);
        // we'll see how to use this pointer below.
        wordPtr := flag.String("word", "default_word", "a string")
    
        // This declares `numb` and `fork` flags, using a
        // similar approach to the `word` flag.
        numbPtr := flag.Int("wordnumb", 0, "an int"). // 这样也可以,前缀相同
        // nextPtr := flag.Int("numb", 0, "an int")
        boolPtr := flag.Bool("fork", false, "a bool")
    
        // It's also possible to declare an option that uses an
        // existing var declared elsewhere in the program.
        // Note that we need to pass in a pointer to the flag
        // declaration function.
        var svar string
        flag.StringVar(&svar, "svar", "defalut_var", "a string var")
    
        // Once all flags are declared, call `flag.Parse()`
        // to execute the command-line parsing.
        flag.Parse()
    
        // Here we'll just dump out the parsed options and
        // any trailing positional arguments. Note that we
        // need to dereference the pointers with e.g. `*wordPtr`
        // to get the actual option values.
        fmt.Println("word:", *wordPtr)
        fmt.Println("numb:", *numbPtr)
        fmt.Println("fork:", *boolPtr)
        // fmt.Println("next:", *nextPtr)
        fmt.Println("svar:", svar)
        fmt.Println("tail:", flag.Args())
    }
    View Code

    在shell文件中写一个,自动生成  时间+名字的文件

    首先肯定是用touch命令,然后的话,我写了这样

    function migrate() {
        version=`date +%s`
    
        if [ ${defaultname}x == ""x ]
        then    defaultname="defaultname" 
        fi
    
        touch ./db/migrations/${version}_${defaultname}.up.sql
        touch ./db/migrations/${version}_${defaultname}.down.sql
    }
    View Code

    直接在terminal中用db.sh migrate name  是可以的。但是去到make migrate name就不行了。不知为何

    然后说说那个判定。首先肯定要fi结尾。。。。

    然后 https://blog.csdn.net/goodlixueyong/article/details/6564591

    具体就是说我的$defaultname可能木有值吧,然后就变成了    == "defaultname"

    也就是左边没有了,所以不行。然后同时加个其他字符就好了。

    最后说说那个参数,defaultname,只能在外面写,不能去到某一个函数里写哦。

    在docker-compose里调用shell文件

      dbrestore:
        image: mysql:5.7
        environment:
          - MYSQL_ROOT_PASSWORD=${MYSQL_ROOT_PASSWORD}
          - DC_DB_HOST=${DC_DB_HOST}
          - DC_DB_SSL_MODE=${DC_DB_SSL_MODE}
          - MYSQL_DATABASE=${MYSQL_DATABASE}
        volumes:
          - ../db:/db
          - ../tools:/tools
        depends_on:
          - db
        links:
          - db
        command: "./tools/deploy.sh dbrestore"
    View Code

    .env文件是给docker-compose文件用的,docker-compose里每一个enviroment才是给docerfile或者外面那些shell文件用的

    如果不加globlelock,那么100个相同的id进来了,就GG

    如果加了,相同的id会被锁住,让一个id先进行成功了,解锁了,然后需要再判断一次,然后就会发现已经存在了。

    package seq
    
    import (
        "sync"
    
        "github.com/sundayfun/daycam-server/db"
        "github.com/sundayfun/daycam-server/db/model"
    )
    
    // TODO: fix temp seq id
    
    var (
        userMutex = make(map[uint64]*sync.Mutex)
        existUser = make(map[uint64]uint64)
        lock      = &sync.Mutex{}
    )
    
    const (
        base = 1000
    )
    
    func init() {
    }
    
    func whetherExist(uid uint64) uint64 {
        if seq, ok := existUser[uid]; ok {
            userMutex[uid].Lock()
            defer userMutex[uid].Unlock()
    
            existUser[uid] = seq + 1
            return seq
        }
    
        return 0 // zero refer to does not exist
    }
    
    func NextSequenceIDByUser(uid uint64) uint64 {
    
        seq := whetherExist(uid)
        if seq != 0 { // user exist
            return seq
        }
    
        lock.Lock()
        defer lock.Unlock()
    
        seq = whetherExist(uid)
        if seq != 0 { // user exist
            return seq
        }
    
        // first time to start main.go
    
        userMutex[uid] = &sync.Mutex{}
        userMutex[uid].Lock()
        defer userMutex[uid].Unlock()
    
        seq := model.LatestSeqByUser(db.GlobalDB, uid)
    
        existUser[uid] = seq + 1
        return seq + 1
    }
    View Code
  • 相关阅读:
    双循环建表____1911年 为 辛亥年
    技巧方法
    sscanf
    02-02环境准备-pyenv与virtualenv以及venv方案对比
    02-01环境准备-virtualenv和venv
    02-01环境准备-pyenv
    【转】解决weblogic启动慢和创建域慢的方法
    chrome新版打开新标签页自动打开谷歌主页
    centos6分辨率设置
    12-openldap使用AD密码
  • 原文地址:https://www.cnblogs.com/liuweimingcprogram/p/8621974.html
Copyright © 2011-2022 走看看