写点什么

英国政府的开源开发

  • 2016-12-04
  • 本文字数:1734 字

    阅读完需:约 6 分钟

为英国政府开发的新代码现在已经开源了。政府数字化服务(Government Digital Service,GDS)技术架构师 Anna Shipman 说,以开源的方式进行代码编写可以让它们被重用,并提高透明度,最后会实现更好的数字服务。Anna Shipman 在 2016 GOTO 柏林会议上谈到了政府的开源行为

我们所做的事情就是要改变政府的工作方式,Shipman 说。英国政府希望提供的非常好的数字化服务,好让大家喜欢使用它们,并最终让政府和公民间可以更好的互动。

英国政府的软件开发以前是每年都用大爆炸式的版本来完成的。近年来这种方式已经改变了,许多团队每天会做几次代码更新。

Shipman 给出了一个例子:当车主们想要转让或保留登记号码时,他们必须要做什么事情。以前,他们不得不填写一张纸质的表格。现在,他们可以在网上填写电子表格,这样做更容易,速度也更快。在线上做这件事也降低了政府的处理成本,所以公民们现在为这项服务支付的费用也减少了。用户们对这项服务的满意度为 91%。

英国政府一直致力于将代码开源,Shipman 说新开发出来的代码应该默认就是开放的。当然用来处理安全或配置相关功能的代码也许可以除外。但即使是这类代码,有些也正在向开放发展。

大部分用于 GOV.UK 服务的代码在 GitHub 上都可以下载。开发过程中项目经历了四个阶段:发现、Alpha、Beta 和生产。这些阶段在政府服务设计手册中会做进一步的解释。

这里的“将代码开放”和“开源开发”是有区别的,Shipman 解释说。“将代码开放”意味着 GDS 不会承诺将来会对代码提供支持,也不承诺它将会一直被维护。同时,GDS 不会准备以这样的代码为中心来建立和支持一个社区。即便是这样,像新西兰、以色列等国家,还有美国的莱克星顿·肯塔基等城市,他们搭建自己的网站时使用的仍是 GDS 的代码。

大多数软件都是以“将代码开放”的方式开发的,但也有一些是开源代码。Shipman 提到了 vCloud 工具,这套在 GDS 内部开发的软件最终由代码开放转变成了开源

今年早些时候,Shipman 在 QCon 伦敦大会上发表了关于英国政府内的 DevOps 的演讲。她在演讲中提到,GDS 在使用开源工具,也在开发开源工具:

GDS 使用了大量的开源工具。其中,他们使用 Jenkins 作为一个 CI 服务器,使用 Puppet 完成 IT 自动化,使用 syslog 和 Logstash 完成日志记录,使用 Cucumber 完成验收测试和 Icinga 完成监控。GDS 还以开放的方式开发了大部分他们使用的工具和应用程序。在 AlphaGov 项目上可以找到所有他们开放出来的工具的源码,但不提供任何方式的支持。GDS 运维团队负责的工具则承担了更多的责任,比如 vCloud 工具。

将代码开放使得代码能被重用,并增加了透明度。Shipman 认为它会强迫你用正确的方式做事情。它的缺点之一是,它可能会让团队里的新员工感到害怕,因为他们写的代码将是人人可见的。GDS 处理这件事情的方法是凭借对代码审查非常正面的态度,并且通过对新员工的帮助来完成的,如结伴编程。

在文章《英国政府的敏捷:一位内部人士透露了一切》中,Nick Tune 讲述了英国政府从开源代码中获得的好处:

另一个 GDS 的辉煌例子是他们如何成功地设法将开源理念引入了政府。不仅仅是使用开源代码,而且是创造开源代码。比如,如果你去浏览一下英国税务及海关总署的 github 网站,你可以看到成百上千的开源项目。而且不仅仅只是库。你可以找到英国税务及海关总署的网页前端代码,也可以找到领域驱动的微服务代码,而这些代码都是在 GOV.UK 网站上实际运行着的。

我对 GDS 取得这样的成就感到惊奇:在政府内促进重用、给纳税人们看他们的钱是怎么被花掉的、并避免了厂商锁定。就我个人而言,我喜欢将代码开放。它对所有的开发者都保持了高标准的工作要求,所以我们不会产生下一代产品的维护负担,因而浪费纳税人的钱,并无法为英国公民创造价值。

Shipman 提到了数字化服务标准:一套所有面向公众的服务领域都必须遵守的18 项标准。该标准包含的部分规定有:软件必须由多学科团队使用敏捷方法迭代式地进行开发;团队必须了解用户的需求,进行不间断的用户研究,并进行端到端的服务测试。

一些GDS 目前正在做的事情是找出最有用的项目,使它们成为开放源代码的候选,找到方式帮助团队用开放的方式进行编码,并增加他们对开源的贡献。

查看英文原文 Open Source Development at the UK Government

2016-12-04 18:002244
用户头像

发布了 152 篇内容, 共 76.1 次阅读, 收获喜欢 64 次。

关注

评论

发布
暂无评论
发现更多内容

假如让你来设计SSL/TLS协议

元闰子

网络安全 TLS 操作系统 ssl SSL/TLS协议

作业四

Geek_f3e842

架构实战营

我的第一个 Flutter 应用之旅

岛上码农

flutter ios 安卓 移动端开发 3月月更

一款开源监控和警报平台:Prometheus

Ethereal

Linux 中的 BusyBox 是什么?如何使用它?

Ethereal

kube-scheduler源码分析(2)-核心处理逻辑分析

良凯尔

Kubernetes 容器 源码分析 Kubernetes, 云原生, eBPF

【架构训练营-模块四】

默光

架构训练营5期 存储架构

从头梳理,看看中国的 ICP 备案制度

白宦成

备案

文章是“自己的”好

BY林子

技术写作

中兴ZXR10 160智能集成多业务路由器快速安装指南,图文并茂!

Ethereal

电商秒杀系统

swallowluo

架构实战营 #架构实战营 「架构实战营」

蚂蚁金服-财富编码军规

Beaver

编码规范 编码军规 蚂蚁金服-财富编码军规

C语言中如何输出汉字;如何用C语言汉字编码输出汉字(超全版)

北极的大企鹅

c 问题处理

c语言结构体中的一个char数组怎么赋值?

北极的大企鹅

c 问题处理

java如何对接企业微信

经典鸡翅

3月月更

Lyft微服务研发效能提升实践 | 4. 基于自动验收测试的部署门禁

俞凡

研发效能 大厂实践 lyft 3月月更

命令行管理 Linux服务器困难?别怕,今天介绍一款基于 Web 的Linux管理神器:Webmin

Ethereal

2022 C语言学习最强干货分享,值得收藏

C语言与CPP编程

程序员 C语言 编程‘

千万级学生管理系统的考试试卷存储方案

「架构实战营」

c语言怎么避免打印空数据?

北极的大企鹅

c 问题处理

站点可靠性工程之旅

俞凡

研发效能 SRE 3月月更

【高并发】两种异步模型与深度解析Future接口

冰河

Java 并发编程 多线程 高并发 异步编程

适合新手代码审计之熊海cms

H

网络安全 代码审计

Studio One 5新版本安装包图文教程

茶色酒

Studio One 5 fl水果20.9

基于STM32设计的森林火灾预警系统

DS小龙哥

物联网 3月月更

web安全之挖掘Linux内核漏洞

网络安全学海

Linux 网络安全 渗透测试 WEB安全 漏洞挖掘

容器化和编排有什么区别?

Ethereal

高并发是一种架构思维模式

陈俊

高并发 技术架构 技术认知

系统学习 TypeScript(六)——认识接口

编程三昧

typescript 前端 3月月更

Go学习笔记——复合数据结构之结构体

为自己带盐

Go 学习笔记 3月月更

智慧车行预约小程序设计方案

CC同学

英国政府的开源开发_开源_Ben Linders_InfoQ精选文章