TOP
お問い合わせ
  1. 掲載のご依頼
  2. メールでのお問い合せ
  3. 電話でのお問い合せ

SEROKUを支える技術〜プロジェクト管理編〜

SEROKUフリーランスを技術。プロジェクト管理編。

こんにちは!初めまして。「SEROKUフリーランス(以下、SEROKU)」の中の人をやっている株式会社WESEEKの haruhikonyan と申します。

SEROKUを支える技術と題して SEROKU で使われている技術をできる範囲で数回に分けて紹介をしていきたいと思います。

[adinserter block="1"]

記念すべき第1回は「プロジェクト管理編」となります。

なんだよプログラミングとかそういう話じゃないのかよ!って人もいると思いますが、プロジェクトを円滑に進めることは立派な技術であると思うので参考になれば幸いです。

フリーランスエンジニア月収診断バナー

スクラムによるアジャイル開発

  • SEROKU開発だけではなくWESEEKではすべてのプロジェクトをスクラムによるアジャイル開発で進めています。
  • アジャイルを採用している理由としては世界的に見ればデファクトスタンダードだということと、ウォーターフォールに比べるとプロジェクトの成功率が高い点にあります。
  • 弊社ではアジャイルでの開発を5年以上も前から行ってきていて、その知見も十分に溜まっていることも理由の一つです。

線表作成

  • 実際は順番は前後してしまうことが多いのですが、数か月先から半年後を見据えた線表を作成して、大まかなSEROKUの施策の展望が見えるようにします。
  • 必ずしも作成した線表厳守というわけではなく、月1程度で見直しをしたり、後述のポイント付けの結果を見て実現不可能と発覚すれば都度修正は行います。
  • 線表があることにより実際の進捗と見比べた際何が遅れてて何は進んでいるのかが関係者全員が把握することができるため優先順位を各々が考えて仕事に取り掛かれることと、目標を見失わなずに済むため、モチベージョンを保つという面でも役になってると言えます。

SEROKUの機能開発時の線表

バックログ作成とポイント付け

  • スクラムにおけるバックログの管理は YouTrack で行っています。
  • まずはユーザストーリーを洗い出し、優先順に並べ変えます
  • そして洗い出したストーリーにチームメンバー全員でストーリーポイントを付けます
    • ポイント付けにはプランニングポーカーと呼ばれるカードゲームのようなものを使い、実際の日時とか時間ではなく、基準となるストーリーの重さに対して相対的な重さをポイントとして付けていきます。
    • 相対的につけることで開発者個人の技術に依存するものではなく、チーム全体としてスピードを測ることができます。

[adinserter block="1"]

Sprint

  • だいたい2週間ごとを一つのタームとしてSprintを回します。
  • 初Sprintでは手さぐりになってしまうのですが、第2Sprintからは前のSprintで消化できたストーリーポイントを参考にチームとして1つのSprintあたり何ポイント消化できるのかを考えて今後のSprint計画を立てていきます。
  • また、2週間のSprint計画が先々まで立てられるようになると、当然理想で考えた線表とのズレが生じてきます。なので先にも述べたように線表はSprintの進み具合によって柔軟に見直しをしていくことが必要となります。

スクラムミーティング

  • 必ず1日の終わりにスクラムミーティングを行います。
  • 前回のスクラムミーティング(前営業日)から行ったことと、次回のスクラムミーティング(翌営業日)までに行う予定を宣言していきます。
  • スクラムミーティング(スクラム開発)で重視することの一つとしてチーム内で合意がとれていることという要素があります。例えば自分が着手するタスクが終わらないと他人の着手したいタスクが着手開始できないといった状態であった場合、当事者間でその認識と合意が取れていないと、場合によっては着手できないタスクを持っている側がいつまでたってもタスクに着手が出来ません。
    • このことをブロックと呼んでいて必ずスクラムミーティングではブロックしている側とブロックされてる側のお互いが報告しなければなりません。

SCRUM(スクラム)MTG時に各自が共有するテキスト

[adinserter block="1"]

振り返り

  • 2週間置きに振り返りを行います。
  • 振り返りの形式としてKTPフレームワークを使っています
  • 振り返りを行うことで、チーム内に顕在化している問題の洗い出しや、他人が実施している良かった施策や、問題点に対しての取り組みをチームで共有し、よりよいチーム運営を行う足掛かりにもなっています。

SEROKUの開発で行われているKPTをもちいた振り返り

 

コミュニケーション

日々のコミュニケーション

  • slackでチャンネルごとに話題を分けて
    • 基本的にはダイレクトメッセージは禁止で、すべての人にやり取りが見えるようにしています。
    • 独り言のように淡々と詰まっていること垂れ流していると、思わぬところから助言が飛んできて解決に導かれるなんてことも日常茶飯事です。
    • もちろんslackだけではなく直接口頭でのやり取りももちろん行っています。
  • 遠方の人とはハングアウト
    • WESEEK には大分支部もあって常にハングアウトが繋がっており、お互いの様子が就業時間中は常に生中継されていて何気ない呼びかけなどもお互いがすぐに気づけ、まるですぐ隣にいるような気分でお互い仕事をしています。

ハングアウトを使った遠隔地とのコミュニケーション

 

週1回の定例

  • 週1回、30分程度の定例ミーティング
  • KPIなどの数字の確認
  • 機能開発の優先度確認
  • 課題や相談したいことを報告し、議論
  • 企画、デザイン、エンジニア各セクションで進捗状況を報告
  • 学生インターンの成果の報告の場

情報共有

  • 開発環境についてや仕様についてなど恒久的に参照され続けられる情報はすべて Growi にマークダウンで記述するようにしています。
  • 細かいタスクの内容などは YouTrack のストーリーやタスクに書くこともあり、Growiのリンクを張るなど互いを併用しています。

[adinserter block="1"]

出てきたツール

  • slack
    • 最近はCMやっている趣味の世界でもビジネスでの世界でも人気急上昇中のチャットアプリケーション
    • Githubや様々なツールへの連携も簡単にできるため採用
    • https://slack.com
  • YouTrack
    • jetbrains製のITS
    • WESEEK では脱redmineすべく導入
    • redmineに比べてチケットの一括移動などの機能や、コマンドでの操作ができるので操作が楽なところが多い。
    • https://www.jetbrains.com/youtrack/
  • プランニングポーカー
  • ハングアウト
    • 東京と大分、そしてほかの会社とも繋ぐgoogle製ビデオチャットシステム
    • 他の者も使ってみたりしたものの一番安定していたので採用
    • https://hangouts.google.com
  • growi
    • マークダウンで書ける高機能のOSS Wikiシステム
    • マークダウンで記述できるwikiシステムということで採用
    • 主なコミッターは。。。?
    • https://growi.org/
  • KTP
    • KTPとは振り返りの手法の一つでKeep, Try, Problemの3つを一人一人発表していく形式である
    • 特徴として発表することについては自分個人のことではなく、必ずチームのことについてであるということです。
      • Keep:この2週間でこの先も続けていきたいこと、Keepしたいこと
      • Try:今後2週間で実施してみたいこと、Tryしたいこと
      • problem:この2週間で困っていて解決不可能なこと、改善のためにどうTryしていいのかわからないもの

[adinserter block="1"]

参考記事

受託開発会社だけど「超ホワイト企業です!」という……その方法は(出典:Team Hackers)」

次回予告

SEROKUを支える技術 開発準備編をお送りする予定です!

 

SEROKUを支える技術 ~開発準備編~
SEROKUを支える技術~プロジェクト管理編~
SEROKUを支える技術~社内 Kubernetes 編~
SEROKUを支える技術~CI/CD編~
SEROKUを支える技術~社内 Kubernetes トラブルシュート前編~
SEROKUを支える技術 Angular Tips その1
SEROKUを支える技術 Angular Tips その2
SEROKUを支える技術 Angular Tips その3

 

SEROKU新規フリーランスエンジニア・プログラマ登録促進バナー

SEROKU新規フリーランスエンジニア・プログラマ登録促進バナー
企業の新規登録用バナー採用したい企業新規登録促進バナー

関連記事