首页 >后端开发 >Golang >从周五黑客到发布:对创建和发布开源项目的思考

从周五黑客到发布:对创建和发布开源项目的思考

王林
王林原创
2024-09-12 18:08:42477浏览

From Friday Hack to Release: Reflections on Creating and Releasing a Open Source Project

금요일 패치 해킹부터 출시까지: 오픈소스 프로젝트 생성 및 출시에 대한 고찰

초보 및 중급 개발자를 대상으로 자신의 아이디어를 오픈 소스 프로젝트로 공개하거나 관심을 갖는 시리즈의 일부입니다.
이러한 반성은 편향적이고 개인적입니다. 더 많은 기사가 예정되어 있습니다. 몇 가지 생각을 공유함으로써 여러분이 자신의 프로젝트를 수행하는 데 영감을 주기를 바랍니다

  • 반성(이것)
  • Java 개발자로서 Go 언어 배우기(TODO)
  • 오픈 소스 건강 및 커뮤니티 파일(TODO)
  • 오픈소스 보안(TODO)

요구 사항

모든 것은 몇 년 전에 시작되었습니다. 때때로 나는 나 또는 다른 사람이 항상 똑같은 Bash 스크립트를 다시 만드는 것과 관련된 것처럼 보이는 무언가가 필요했습니다.
전반적인 요구 사항은 높은 수준인 경우가 많기 때문에 간단했습니다.
우리 개발자들이 주로 하는 일은 A지점에서 B지점으로 정보를 섞는 것 뿐입니다. 그렇죠?

여기서 목표는 여러 Git 저장소를 다른 Git 제공자, 디스크, 아카이브 형식, CLI 앱으로 미러링하는 것이었습니다.
나는 개인적으로나 직장에서 이것이 필요했습니다. 사람들이 이런 일을 수동으로 처리하는 데 많은 시간을 투자하는 것을 보니 마음이 불편합니다.

그래도 항상 단순한 Bash 스크립트로 유지되는 것 같았습니다. 신속하게 완료되지만 특별한 경우, 오류 처리, 모듈화, 패키징 등 추가 사항이 추가되어야 하는 경우 - 우리 대부분이 동의하는 것처럼 Bash 스크립트는 더 큰 도구를 지원하지 않습니다.

그래서 이를 위한 완전한 CLI 애플리케이션을 만들기로 결정했습니다.

사전 결정

그러한 도구가 이미 존재합니까?

가장 먼저 해야 할 일은 바퀴를 재발명하지 않는 것이었습니다.
오픈 소스로 이 문제를 해결하는 몇 가지 도구가 있습니다. Go로 작성된 최소한 하나, Bash 스크립트 몇 개, 그리고 Gitea와 같은 가져오기 기능을 포함하는 경우.
나는 그것들을 시험해 보았지만 내가 원하는 방식으로 완전히 작동하는 것을 찾을 수 없었습니다. 그리고 프로젝트를 어디로 진행하고 싶은지에 대한 다른 생각이 있었기 때문에 깊이 들어가지 않기로 결정했습니다
기존 프로젝트에 패치를 적용하기 시작했습니다.

상업적인 도구도 몇 가지 있지만, 이 작은 도구는 오픈소스 형태로도 존재해야 한다고 느꼈습니다.

결론: 이 세상에는 이 CLI 도구가 있을 곳이 있었습니다.

Work-hackdays나 개인적인 자유 시간에 해킹을 하시나요?

스프린트가 끝날 때나 다른 경우에는 직장에서 해킹 시간을 가집니다. 한 가지 접근 방식은 시간이 지남에 따라 이러한 상황에서 이를 해킹하여 유용한 것으로 만드는 것입니다.
나는 다음과 같은 이유로 개인 여가 시간에 완전히 하기로 빨리 결정했습니다.

  • 직장에서의 해킹 기회는 전체 프로젝트를 장기간 진행하는 것이 아니라 짧은 학습과 창의성을 발휘하는 데 사용해야 합니다.
  • 해당 솔루션이 핵심 조직의 비즈니스에 적합하지 않습니다. 그렇다면 항상 이상한 일이 될 것입니다.
  • 업무에 연결하면 더 많은 일을 하는 것처럼 느껴질 것입니다. 저는 재미를 위해 이 일을 하며 바둑 등을 배우고 있습니다. 그러면 나에게 압박감과 스트레스가 가해질 것입니다.
  • 업무 시간에 작업을 수행하면 시간이 오래 걸릴 것입니다. 몇 시간, 몇 주에 걸쳐 진행됩니다.

결론: 남는 시간에 재미있게 해야겠다.

기술 스택 선택

저는 JS/TS, Python/Ruby에서 몇 가지 프로젝트를 진행하면서 수년 동안 Java/Kotlin 세계에서 대부분의 시간을 보냈으며 모든 수석 개발자와 마찬가지로 때때로 다른 작업도 하기도 했습니다.
하지만 오랫동안 저는 Go나 Rust를 정말 배우고 싶었습니다. 그래서 새로운 언어에 뛰어들 수 있는 동기를 얻을 수 있는 기회가 될 것입니다
Go를 선택한 이유는 Open Source DevOps 세계의 꽤 많은 CLI 애플리케이션이 Go로 작성되어 있고, 때때로 타사 프로젝트에 패치를 제출할 수 있기를 원하기 때문입니다. 또한 Go로 작성한다는 것은 여러 대상 아키텍처가 포함된 하나의 바이너리를 의미합니다.

예를 들어 Pico CLI 및 GraalVM을 사용하면 Java에서 이 작업을 수행할 수 있었는데, 이전 시도 이후 좋은 인상을 받았지만 대신 Go를 배우고 싶다고 결정했습니다.

결론: Go로 해보고 배워야겠습니다.

기타 학습 목표

이를 통해 대부분의 보안 관행(스코어카드, SLSA,

)을 따라 멋지게 패키지된 오픈 소스 프로젝트를 제공하는 주제에 대해 더 깊이 탐구하고 싶었습니다. GoRelease와 같은 도구를 사용하여 다양한 종류의 빌드를 만들 수 있습니다.

결론: 원하는 주제를 배우고 탐구할 수 있는 기회를 가져보세요.

Kekalkan Skop

Memandangkan saya merancang untuk banyak bereksperimen dan saya benar-benar baru dalam Go, saya tahu saya akan melakukan banyak kerja tidak berstruktur.
Di sini adalah penting untuk menetapkan skop - bilakah ia cukup bagus untuk keluaran alfa?
Saya pada awalnya memutuskan fungsi yang sepatutnya ada, dan walaupun menggoda untuk duduk dan memperhalusi dan mengembangkannya lagi, ini bagus.
Saya boleh duduk dengan ini untuk masa yang lama.

Kesimpulan: Lepaskan projek sebagai alpha apabila anda sama-sama malu dan bangga dengannya.

Anggaran - Sejauh Mana Sukarnya?

Mempelajari bahasa baharu ialah sebahagian kecil daripada mempelajari bahasa itu sendiri, tetapi lebih banyak lagi tentang mempelajari ekosistem dan simpulan bahasanya.
Apakah perpustakaan yang digunakan, bagaimana ia digunakan, apakah cara idiomatik untuk melakukan ini dan itu?
Saya perlu menghabiskan banyak masa untuk belajar dan menyelidik semasa projek ini, mungkin 50% daripada masa saya akan
telah menghabiskan hanya pengekodan dalam bahasa dan ekosistem yang saya tahu.

Kesimpulan: Gandakan anggaran masa anda dengan tiga apabila mempelajari susunan teras baharu dan melibatkan percubaan. Sintaks bahasa akan menjadi perkara kecil.

Proses Penciptaan

Komitmen Awal

Pelaksanaan asas dilakukan dalam sehari - ia tidak mempunyai binaan, pengendalian ralat, dokumentasi, kes tepi, kebolehselenggaraan, dsb.
Di sinilah kebanyakan penggodaman pada hari Jumaat berakhir, dan kebanyakannya tidak pernah pergi lebih jauh.

Tetapi seperti yang diketahui oleh semua pembangun kanan, membuat sesuatu berfungsi adalah jauh daripada mengeluarkan produk.

Tak lama lagi, eh? Tidak juga.

Mencari Masa

Ada kalanya sukar mencari masa untuk meluangkan masa dengan projek itu, terutamanya kerana saya mempunyai musim bunga yang meletihkan di tempat kerja.
Bukan setiap malam anda berasa seperti membaca buku selama 2 jam tentang sesuatu yang khusus atau mempelajari teknologi baharu.
Atau menghabiskan masa menulis dokumentasi. Saya mempunyai anak dan rumah, dan saya tidak mampu untuk membiarkan projek persendirian memakan diri saya lebih daripada hobi lain.
Tetapi sesuatu yang sentiasa perlu diberikan - Saya akhirnya menonton lebih sedikit siri, dan sebarang permainan hampir tidak wujud dalam tempoh ini.

Dengan itu, walaupun saya berharap saya dapat meluangkan lebih banyak masa pada projek itu, ia hampir selalu memberi motivasi - Saya mempunyai beberapa sesi malam di mana saya kurang tidur dan berkod atau belajar,
kerana saya sangat teruja untuk pergi lebih jauh. Selain itu, apabila sesuatu yang menyeronokkan, ia adalah menyeronokkan, sama ada mengangkat berat, menulis buku, mengembangkan, dsb.

Perkara yang Saya Lupa

Saya sudah terbiasa bekerja dalam pasukan sejak sekian lama. Dengan projek solo, anda perlu menguruskan lebih banyak topi dan menjadi agak baik dalam setiap bahagiannya, tidak selalunya teknikal.
Saya menghabiskan banyak masa untuk menggali reka bentuk CLI yang baik dan pilihan idiomatik. Bidang lain ialah proses pelepasan dan binari binari untuk platform yang berbeza.
Mengikuti SLSA dan piawaian lain dalam Sumber Terbuka juga mengambil masa. Dan kami mahukan liputan ujian yang baik, bukan?
Bekerja dalam satu pasukan, orang lain diharapkan dapat melakukan logo yang anda mahukan, dokumentasi yang perlu ditulis.
Bekerja solo, itu hanya anda atau ia tidak akan berlaku.
Menulis kod tidak sampai 50% daripada menyampaikan projek. Dan ada yang lain.

Sindrom Penipu Melanda

Sindrom Penipu adalah perkara biasa dalam dunia pembangun berasaskan pengetahuan kami. Setiap orang mempunyai kemahiran yang berbeza, dan pada bila-bila masa, akan sentiasa ada seseorang yang lebih tahu daripada anda.
Berada dalam satu pasukan, anda mempunyai seseorang untuk berbincang.
Sendiri, tidak sebanyak.

Tetapi, ini semua tentang menerima bahawa seseorang akan melakukan beberapa perkara bodoh dalam kod pada masa-masa tertentu.
Dan, Sumber Terbuka itu bukan tentang menjadi sempurna. Ini tentang belajar, menyelesaikan dan melepaskan perkara yang mungkin berguna kepada orang lain.

The Grind

Nah, apa yang boleh saya katakan - ia dilakukan apabila ia selesai.

Terdapat beberapa waktu penyahpepijatan lewat malam, pemfaktoran semula, tetapi juga detik aliran dan dopamin yang tidak terkira banyaknya.

Bagi saya, masa keluaran tiba apabila saya merasakan seni bina keseluruhan dalam projek tidak akan bergerak secara radikal - saya telah mengenal pasti antara muka dan merasakan ia boleh dilanjutkan.
Pangkalan kod OK.
Kebanyakan ciri asas ada dan sementara segala-galanya disediakan untuk penambahbaikan, ia masih menjadi asas untuk diusahakan.

Kesudahan dan Pengajaran

  1. Tetapkan skop awal: Tentukan tempat untuk berhenti. Sediakan struktur projek, dokumentasi, keluaran, saluran paip dan garis panduan komuniti anda lebih awal. Masa depan anda akan berterima kasih kepada anda.

  2. Jangan stress, nikmati proses pembelajaran: Ia dilakukan apabila ia selesai.

  3. Tekun: Sumber terbuka ialah maraton, bukan pecut. Jangan burn out. Ia adalah hobi, bukan kehidupan anda. Namun tetap gigih. Lakukan perkara kecil setiap hari.

  4. 学习,学习,学习:将一切视为学习和改进的机会,而不是问题。

  5. 编码是最简单的部分:主要代码会花费你最少的时间;其他一切,例如文档、测试等,都是花费时间的地方。

  6. 做额外的事情:它们和编码一样有趣。是的,即使是文档也可以节省您解释和重新解释的时间。如果让你感到无聊,那就让它变得有趣。文档即代码、vim-pong 等

  7. 休息一下:倦怠是真实存在的。当你需要的时候退后一步。就像其他创造性学习过程一样,分批进行。

  8. 使用系统:尽早在实践和现实世界中使用你自己的狗粮。更好的是,找到一个人/社区来提供反馈。

  9. 享受旅程:创造真是太棒了。

  10. 完成它:这个世界上有无数未完成的项目。完成它。

  11. 使用人工智能作为帮助:我通过委派一些额外的工作来节省时间,例如要求代码改进、代码审查、文档结构、总结等。但是,不要永远盲目地相信它。回顾并批评答案。

好了,黑客快乐,现在去想想你下一步想要做什么!!

链接

项目:Git Provider Sync

以上是从周五黑客到发布:对创建和发布开源项目的思考的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn