[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
reference: http://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.-alpine3. COPY . $GOPATH/src/database-work WORKDIR $GOPATH/src/database-work/server RUN go build -o main main.go ENTRYPOINT ["./main"] # must use ./main
一般你的dockerfile会这样写,需要写上workdir,但是由于你的.go往往会有"github.com/xxx/xxx"
所以被迫你的dockerfile的workdir也就是你现在工程的workdir了
shell file
* in the first letter can not get space
#!/bin/bash 不能有空格,在#和!中
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", , "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())
}
在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
}
直接在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"
.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 =
) func init() {
} func whetherExist(uid uint64) uint64 {
if seq, ok := existUser[uid]; ok {
userMutex[uid].Lock()
defer userMutex[uid].Unlock() existUser[uid] = seq +
return seq
} return // zero refer to does not exist
} func NextSequenceIDByUser(uid uint64) uint64 { seq := whetherExist(uid)
if seq != { // user exist
return seq
} lock.Lock()
defer lock.Unlock() seq = whetherExist(uid)
if seq != { // 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 +
return seq +
}
[inner] bug的更多相关文章
- Tomcat一个BUG造成CLOSE_WAIT
之前应该提过,我们线上架构整体重新架设了,应用层面使用的是Spring Boot,前段日子因为一些第三方的原因,略有些匆忙的提前开始线上的内测了.然后运维发现了个问题,服务器的HTTPS端口有大量的C ...
- a标签点击跳转失效--IE6、7的奇葩bug
一般运用a标签包含img去实现点击图片跳转的功能,这是前端经常要用到的东西. 今天遇到个神奇的bug:如果在img上再包裹一层div,而且div设置了width和height,则图片区域点击时,无任何 ...
- 关于 Chrome 浏览器中 onresize 事件的 Bug
我在写插件时用到了 onresize 事件,在反复地测试后发现该事件在 Chrome 及 Opera(内核基本与 Chrome 相同,以下统称 Chrome)浏览器打开时就会执行,这种情况也许不能算作 ...
- Chrome出了个小bug:论如何在Chrome下劫持原生只读对象
Chrome出了个小bug:论如何在Chrome下劫持原生只读对象 概述 众所周知,虽然JavaScript是个很灵活的语言,浏览器里很多原生的方法都可以随意覆盖或者重写,比如alert.但是为了保证 ...
- 一个粗心的Bug,JSON格式不规范导致AJAX错误
一.事件回放 今天工作时碰到了一个奇怪的问题,这个问题很早很早以前也碰到过,不过没想到过这么久了竟然又栽在这里. 当时正在联调一个项目,由于后端没有提供数据接口,于是我直接本地建立了一个 json ...
- 了不起的 nodejs-TwitterWeb 案例 bug 解决
了不起的nodejs算是一本不错的入门书,不过书中个别案例存在bug,按照书中源码无法做出和书中相同效果,原本兴奋的心情掺杂着些许失落. 现在我们看一下第七章HTTP,一个Twitter Web客户端 ...
- 应该是Angular2的一个bug?
为了应对未来的趋势,及时赶上下一趟互联网技术,我最近也在通过具体项目研究angular2,首先必须要吐槽的是,学习angular2的成本本身不高,但是一堆的工具.配置实在让人 很是焦灼,就像asp.n ...
- 记录一次bug解决过程:数据迁移
一 总结 不擅长语言表达,勤于沟通,多锻炼 调试MyBatis中SQL语法:foreach 问题:缺少关键字VALUES.很遗憾:它的错误报的让人找不着北. 二 BUG描述:MyBatis中批量插入数 ...
- 关于MJRefresh的下拉加载数据bug
当没有更多数据的时候显示NoMoreData 我的理解是先结束刷新再显示没有更多 今天之前一直没发现有问题 贴之前的代码 [self.collectionView reloadData]; [self ...
- [异常特工]android常见bug跟踪
前言 对app的线上bug的收集(友盟.云捕等)有时会得到这样的异常堆栈信息:没有一行代码是有关自身程序代码的.这使得对bug的解决无从下手,根据经验,内存不足OOM,Dialog关闭,ListVie ...
随机推荐
- WordCount-软件测试初体验
github:https://github.com/skz12345/WordCount PSP2.1 PSP阶段 预估耗时(分钟) 实际耗时(分钟) Planning 计划 40 60 · Esti ...
- java全栈day01-02入门案例
一 在开始案例之前,我们需要了解一下Java应用程序的编写流程. 通过上图我们可以了解到编写的程序大致如下: 1 源文件:编写Java源文件(我们也称之为源代码文件),它的扩展名为.java: 2 ...
- Json数据导出生成Excel
最近在做一个导入导出Excel的功能,导出其他类型的文件都比较熟悉,但是导入跟导出一个Excel还是稍微特殊点.根据这次的经验,写了个导出的小样例. 总体思路就是json数据的key,value跟Ex ...
- iTween插件使用
itween插件 itween是一个动画库,作者创建它的目的就是最小的投入实现最大的产出.用它可以轻松实现各种动画,晃动,旋转,移动.褪色.上色.控制音频等. iTween原理: itween的核心是 ...
- vs code进行c/c++开发
vs code是微软公司开发的跨平台编辑器,丰富的插件功能可以满足各种编程语言的编码,编译和调试.由于vs code本身只是一个编辑器,所以你需要准备编译工具链.本文针对的是windows系统,我这里 ...
- Unity UGUI 原理篇(二):Canvas Scaler 縮放核心
https://blog.csdn.net/gz_huangzl/article/details/52484611 Canvas Scaler Canvas Scaler是Unity UI系統中,控制 ...
- AOP切点相关
1.切点定义 切点定义包含两个部分 一个切入点表达式 一个包含名字和任意参数的方法签名 package com.sysker.aspect; import org.aspectj.lang.annot ...
- spring 和 mybatis 整合过程 (包含分页)
1.spring-mybatis.xml : 配置 SqlSessionFactory 和 MapperScannerConfigurer <bean id="sqlSessio ...
- 圆环进度css
看效果先:http://sandbox.runjs.cn/show/b6bmksvn 参考: jquery圆环百分比进度条制作 CSS clip:rect矩形剪裁功能及一些应用介绍 CSS clip: ...
- ubuntu下vnstat监控网卡流量
vnstat使用 vnstat 是另一个可以用来监视带宽使用量的程序.它比ipac-ng更简单易用. vnstat的一个优点是它不是一个运行的守护程序,所以它几乎不占用内存.它由 cron 任务创建, ...