有时候,我们使用go语言开发一些程序的时候,往往出现多个进程同时操作同一份文件的情况,这很容易导致文件中的数据混乱。 我们需要采用一些手段来平衡这些冲突:需要锁操作来保证数据的完整性,这里介绍的针对文件的锁,称之为“文件锁”-flock。

对于flock,我们最常见的例子就是nginx,进程起来后就会把当前的PID写入这个文件,当然如果这个文件已经存在了,也就是前一个进程还没有退出,那么Nginx就不会重新启动。

flock 是对于整个文件的建议性锁。也就是说,如果一个进程在一个文件(inode)上放了锁,那么其它进程是可以知道的。(建议性锁不强求进程遵守。) 最棒的一点是,它的第一个参数是文件描述符,在此文件描述符关闭时,锁会自动释放。而当进程终止时,所有的文件描述符均会被关闭。所以很多时候就不用考虑类似原子锁解锁的事情。

package main
import ("fmt""os""sync""syscall""time"
)
//文件锁
type FileLock struct {dir stringf   *os.File
}
func New(dir string) *FileLock {return &FileLock{dir: dir,}
}//加锁
func (l *FileLock) Lock() error {f, err := os.Open(l.dir)if err != nil {return err}l.f = ferr = syscall.Flock(int(f.Fd()), syscall.LOCK_EX|syscall.LOCK_NB)if err != nil {return fmt.Errorf("cannot flock directory %s - %s", l.dir, err)}return nil
}//释放锁
func (l *FileLock) Unlock() error {defer l.f.Close()return syscall.Flock(int(l.f.Fd()), syscall.LOCK_UN)
}func main() {test_file_path, _ := os.Getwd()locked_file := test_file_pathwg := sync.WaitGroup{}for i := 0; i < 10; i++ {wg.Add(1)go func(num int) {flock := New(locked_file)err := flock.Lock()if err != nil {wg.Done()fmt.Println(err.Error())return}fmt.Printf("output : %d\n", num)wg.Done()}(i)}wg.Wait()time.Sleep(2 * time.Second)}

上面的代码我们演示了同时启动10个goroutinue,但在程序运行过程中,只有一个goroutine能获得文件锁(flock)。 其它的goroutinue在获取不到flock后,会抛出异常的信息。这样即可达到同一文件在指定的周期内只允许一个进程访问的效果。
代码中文件锁的具体调用:syscall.Flock(int(f.Fd()), syscall.LOCK_EX|syscall.LOCK_NB)
我们采用了syscall.LOCK_EX,syscall.LOCK_NB,这是什么意思呢?

flock,建议性锁,不具备强制性。一个进程使用flock将文件锁住,另一个进程可以直接操作正在被锁的文件,修改文件中的数据, 原因在于flock只是用于检测文件是否被加锁,针对文件已经被加锁,另一个进程写入数据的情况,内核不会阻止这个进程的写入操作,也就是建议性锁的内核处理策略。

flock主要三种操作类型:

  • LOCK_SH,共享锁,多个进程可以使用同一把锁,常被用作读共享锁;
  • LOCK_EX,排他锁,同时只允许一个进程使用,常被用作写锁;
  • LOCK_UN,释放锁;
    进程使用flock尝试锁文件时,如果文件已经被其他进程锁住,进程会被阻塞直到锁被释放掉,或者在调用flock的时候,采用LOCK_NB参数。 在尝试锁住该文件的时候,发现已经被其他服务锁住,会返回错误,errno错误码为EWOULDBLOCK。

flock锁的释放非常具有特色,即可调用LOCK_UN参数来释放文件锁,也可以通过关闭fd的方式来释放文件锁(flock的第一个参数是fd),意味着flock会随着进程的关闭而被自动释放掉。

ps: flock其中的一个使用场景为:检测进程是否已经存在。

Golang入门之——文件锁操作flock相关推荐

  1. 每天进步一点点——Linux文件锁编程flock

    转载请注明出处:http://blog.csdn.net/cywosp/article/details/30083015 1. 场景概述     在多线程开发中.相互排斥锁能够用于对临界资源的保护,防 ...

  2. 文件锁操作《精通Unix下C语言编程与项目实践》之三

    文章试读 不拘一个遍程序系列:编程序不能一个脑袋钻到底,有时要学会变通,即所谓的曲线救国.一.二.三.四 职场规划:一些杂七杂八的职场感悟吧.不值钱的软件人才 精力充沛与事业成功 我的诗歌:都是我的打 ...

  3. Golang入门(4):并发

    Golang入门(4):并发 摘要 并发程序指同时进行多个任务的程序,随着硬件的发展,并发程序变得越来越重要.Web服务器会一次处理成千上万的请求,这也是并发的必要性之一.Golang的并发控制比起J ...

  4. golang开发工程师-第一步:golang入门基础教学

    golang入门基础教学 前言 一.golang的优势何在? 二.goland破解教程 三.goland的使用教程 四.一个简单的go代码 五.变量的声明和赋值 六.数据类型的基本介绍 七.访问权限[ ...

  5. php tp3 操作绑定到类,快速入门 17:操作绑定到类

    # 快速入门(十七):操作绑定到类 如果你的应用规模比较大,每个操作方法彼此相对独立,那么就可以尝试下操作绑定到类的功能. ## 定义 系统提供了把每个操作方法定位到一个类的功能,可以让你的开发工作更 ...

  6. mysql数据的引用_MySQL数据库入门:mysql操作和程序引用

    本文主要向大家介绍了MySQL数据库入门的mysql操作和程序引用,通过具体的实例让大家了解,希望对大家学习MySQL数据库入门有所帮助. mysql操作: 创建qrdata2表: create ta ...

  7. golang入门实战(二)

    golang入门实战 github 接上篇 接口数据时间格式 token校验中间件 多平台打包 未完待续 github 项目完整代码–github 接上篇 golang入门实战(一) 接口数据时间格式 ...

  8. Golang 数组的简单操作之合并数组与删除某个索引的值

    Golang 数组的简单操作之合并数组与删除某个索引的值 Golang轻松学习 文章目录 Golang 数组的简单操作之合并数组与删除某个索引的值 一.接口数组([]interface{})是什么? ...

  9. 短视频运营:如何做自媒体?新手入门的详细操作分享

    经常听到这样一些言论,目前自媒体已经过时了,普通人根本挣不到钱,真相是否像别人说的一样呢? 其实,在我们身边经常会看到一些网红大V,一个月轻轻松松月入百万.月入千万的人已经大有人在,而这些网红往往都是 ...

最新文章

  1. 10月书讯 | 跟着泰拉去冒险
  2. Matlab 2022a 安装教程(手把手式教程 超简单)
  3. DjangoAPP子路由
  4. Kafka会不会重复消费
  5. window.load和$(document).ready()事件
  6. 适配器模式之解释器模式
  7. acer软件保护卡怎么解除_Acer软件保护卡
  8. 小程序中的image标签
  9. linux 硬盘合并使用方法,Linux硬盘合并的实现代码
  10. npm install报错的一天
  11. Python打印表格
  12. 第四届“绽放杯”5G应用征集大赛圆满落幕 中国移动参与项目获奖数量四年蝉联第一
  13. Debezium系列之:使用Debezium接入PostgreSQL数据库数据到Kafka集群的详细技术文档
  14. 房贷没放款前千万不要做的事
  15. Microsoft Office无法验证此应用程序的许可证怎么解决
  16. html简洁风格的个人博客网站模板(源码)
  17. 开发流程中的问题总结和建议
  18. python 电脑状态_Python实现简单状态框架的方法 -电脑资料
  19. ZIP、RAR压缩包,忘记压缩包密码怎么办?
  20. 在vmware workstation中构建局域网

热门文章

  1. Word2010下划线不显示
  2. ACCV 2020国际细粒度网络图像识别竞赛——正式开赛!
  3. python两张图片无缝合成一张,Python实现拼接多张图片的方法
  4. Typora结合Git打造完美的个人云笔记本
  5. 数字化转型企业人才画像
  6. 新、JQ知识点笔记整理。
  7. uniapp使用讯飞语音合成
  8. Gartner:2017年中国新兴技术成熟度曲线
  9. 怀孕计算机在线,【怀孕天数计算器在线计算_怀孕天数计算器在线计算专题】- 天鹅到家...
  10. 记录-吴军《硅谷来信》有感