De geek à directeur technique

Le blog d'un geek devenu directeur technique

Aller au contenu | Aller au menu | Aller à la recherche

Tag - organisation

Fil des billets - Fil des commentaires

lundi 22 mars 2010

Réduire les goulots d'étranglement

Un lecteur de ce blog a fait appel à moi récemment pour l'aider à améliorer l'organisation de son entreprise. Je ne suis pas consultant et je ne cherche pas à l'être, mais j'ai grandement apprécié l'expérience. Je ne vais évidemment rien divulguer de confidentiel à ce propos, mais j'ai quand même envie de partager avec vous quelques éléments fondamentaux de notre discussion.

Il s'agit presque d'un cas d'école : Une petite entreprise qui existe depuis assez longtemps, et avec juste assez de turn-over, pour qu'une partie non négligeable de la connaissance d'entreprise (expérience des clients, expertise technique, gestion des projets) soit concentrée sur le patron. Certains projets ont beau être gérés par d'autres personnes, il continue à jouer un rôle central qui finit par ralentir l'ensemble de l'activité.

Je lui ai proposé un plan de bataille en trois étapes :

  1. Déléguer
  2. Communiquer
  3. Définir un référentiel

Déléguer

Il me semblait important de commencer par imposer une nécessité : Déléguer tous les projets. Quand on est patron d'une entreprise, il faut pouvoir avoir un œil sur l'ensemble des projets, pouvoir intervenir dessus quand il le faut ; mais il ne faut pas être la personne qui a la responsabilité de la réussite du projet.

En déléguant chaque projet, on responsabilise les membres de l'équipe, et on se ménage la possibilité d'aider chaque projet au mieux en fonction des besoins.

Pour résumer, lorsqu'une personne concentre ainsi une majorité de connaissances, elle ne peut pas se consacrer à un projet − cela aurait un impact trop négatif sur tous les autres. Il faut prendre de la hauteur.
Être un manager et non un leader.

Par contre, il faut bien comprendre que la délégation des responsabilités ne veut pas dire qu'on se lave les mains des projets. Il faut au contraire forcer les collaborateurs à découper leurs tâches le plus finement possible. Ainsi il sera facile de définir les priorités entre les tâches, d'évaluer leurs durées, bref de combattre l'effet tunnel.

Communiquer

C'est bien beau de tout déléguer, mais cela fait prendre des risques. Et quand on a pris l'habitude d'être au centre de tous les projets, c'est forcément un peu effrayant.

La plupart des entreprises organisent une réunion hebdomadaire de suivi de projets. Sauf qu'il est difficile de passer le reste de la semaine sans avoir une vision précise de l'avancement des projets, et en cas de soucis on peut rapidement se prendre une semaine entière de retard. C'est ce qui amène souvent à faire du micro-management : on passe son temps à regarder au-dessus de l'épaule des autres, pour savoir où ils en sont ; c'est inefficace et désagréable.

Lire la suite...

jeudi 11 février 2010

Le «harcèlement positif» comme méthode de travail

Il y a environ un an, je vous parlais du logiciel Action Method. Il propose une fonctionnalité «nagging», qui permet de rappeler au responsable d'une tâche que celle-ci réclame une attention particulière ou une exécution rapide.
J'aime bien cette fonction toute simple mais très utile. J'ai implémenté la même chose dans l'outil de gestion de projets qu'on utilise en interne dans mon entreprise, et je pense l'inclure au projet Skriv.

Les leviers de productivité

Avec le temps, je me suis rendu compte que je me servais − et je ne suis pas le seul − du «harcèlement» comme d'une manière normale de travailler. Non pas que je harcèle les gens avec qui je bosse (c'est puni par la loi !), mais je les incite à me harceler.

Je m'explique : De par mon poste de directeur technique, je suis amené à réaliser un certain nombre de choses par moi-même, mais une part importante de mon travail est de permettre aux autres de travailler. Que ce soit en débloquant un développeur qui reste scotché sur un bug, en aidant l'administrateur sur des tâches IT, en discutant de spécifications avec un chef de projet, en organisant les procédures d'une équipe, ... je passe plus de la moitié de mon temps à “mettre de l'huile dans les rouages“.
C'est un calcul simple à faire : Cette vingtaine de personnes, si je peux faire quelque chose pour la rendre plus productive, elle générera plus de résultats que si je me concentre uniquement sur mes tâches. Et même si je ne réussis qu'à améliorer la productivité de 3 personnes, ça en vaudra la peine.

Petit aparté : Cette manière de faire peut être dangereuse si on ne la maîtrise pas. Il ne faut pas devenir le point de passage obligatoire pour toutes les réalisations, sinon on se transforme en goulot d'étranglement. Au lieu de rendre les gens plus productifs, on ralentit au contraire leur travail.

Priorités vs réactivité

Malheureusement, devenir un tel «point central» fait qu'il y a souvent un défilement incessant de personnes qui viennent me demander quelque chose. Parfois c'est juste pour avoir une info ou pour me demander mon avis avant de prendre une décision, d'autres fois c'est pour me demander de réaliser une opération qui va prendre plus de temps.

Au début, je notais les requêtes au fur et à mesure qu'elles arrivaient, en utilisant ma todo-list personnelle, ou notre buglist ou notre logiciel de gestion des tâches. Mais ça ne fonctionnait pas. Les requêtes s'empilaient sans que les demandeurs ne fassent l'effort de réfléchir aux priorités de leurs demandes. Je les traitais suivant leur ordre d'arrivée et non pas suivant leur importance ; j'étais dans la réaction et pas dans la planification.
Évidemment, j'aurais pu simplifier les choses en répondant à chaque demande «Tu as créé un ticket dans la buglist ?», et attendre le lendemain pour revoir l'ordre de priorité de toutes les tâches en attente. Mais perdre en réactivité n'est pas la bonne réponse à un problème d'identification des priorités.

Le harcèlement positif

Au final, quand quelqu'un a besoin de moi, il y a 3 scénarii :

  1. Je suis occupé à faire quelque chose d'important et long. Je demande de revenir plus tard, mais je m'informe quand même de l'importance de la demande (au cas où).
  2. Je suis occupé, mais je n'en ai plus que pour 2 minutes. Je demande à la personne de s'asseoir à côté de moi et d'attendre que j'ai fini. Quand les demandes ne sont pas si importantes que ça, les gens n'ont naturellement pas la patience d'attendre. Ils agissent comme si j'allais systématiquement m'arrêter de travailler pour traiter leurs requêtes dans la seconde ; mais si on leur demande à eux d'attendre, ils y réfléchissent à 2 fois.
  3. Il y a déjà plusieurs personnes qui font le pied de grue pour utiliser mon «temps machine». Dans ce cas, on évalue collégialement les priorités. Mais il y a un effet naturel qui s'ajoute : Lorsque quelqu'un attend depuis longtemps, il fait ce qu'il faut pour ne pas continuer à attendre ; soit il finit par abandonner (ce n'était pas si important finalement), soit il réussit à nous convaincre de l'importance de sa demande.

Quand quelqu'un a réussi à m'atteindre (si je puis dire), je lui demande de rester assis à côté de moi pendant tout le temps que je vais prendre pour réaliser ce qu'il me demande. Ceci est valable pour toutes les tâches «normales». Si une tâche va me prendre plusieurs heures, je l'intègre à ma todo-list globale.
On pourrait s'étonner du fait que je force des non-techniciens à rester près de moi, même quand je ne fais qu'exécuter des actions techniques. Pourtant, c'est justement ce qui fait que cela fonctionne :

  • Si la personne s'en va, il y a de gros risques que quelqu'un d'autre arrive juste derrière et me fasse travailler immédiatement sur une tâche plus urgente. Cela a moins de chances d'arriver si je suis visiblement occupé avec une autre personne.
  • Si la personne qui me demande quelque chose ne peut pas rester avec moi, si elle a plus important à faire que de s'assurer que je m'en occupe rapidement, c'est sûrement que ce qu'elle me demande n'est pas très important. Ou en tout cas, cela veut dire que j'ai moi aussi d'autres tâches plus importantes dont il faut que je m'occupe.
  • En gardant les requérants auprès de moi, je peux leur donner les informations qui leur permettront d'être indépendants la prochaine fois. Si par contre je m'en charge toujours de A à Z, tout seul dans mon coin, il n'y a aucune chance qu'ils montent en compétence.
  • Au moment où la tâche est terminée, ils en ont aussitôt un statut exact et complet. Il n'y a pas de tergiversation, il n'y a pas de perte d'information à cause d'une communication incomplète.

Qu'en penser ?

Je suis conscient de l'aspect complètement empirique de cette manière de travailler. Peut-être qu'elle ne peut pas s'appliquer à toutes les personnes ni à toutes les situations. Mais je l'ai vu fonctionner à maintes reprises, et ça fonctionne dans mon entreprise.

D'une certaine manière, cela me rappelle certains aspects de la méthode Getting Real de 37signals. Entre autres son paragraphe Start With No. On peut y retrouver des notions similaires :

  • On doit parfois ajouter des contraintes pour devenir plus efficace.
  • Les idées importantes finissent toujours par se faire entendre. Sans système de filtrage, c'est la cacophonie.

samedi 12 décembre 2009

Les premiers enseignements de Rework

J'ai déjà parlé plusieurs fois de l'entreprise 37signals, de ses logiciels de gestion de documentation et de projet, et de sa méthode Getting Real. Actuellement, ses membres travaillent au successeur de leur livre, dont le nom sera Rework. Ils ont présenté quelques bribes d'information sur le livre, et je me suis arrêté sur le quatrième de couverture :

Je trouve que le texte qui s'y trouve est très intéressant, un brin controverse, et mérite qu'on s'y attarde. Voici une traduction très libre de son contenu, et ce que j'en pense.

“Dès que possible” est un poison

Il est vrai qu'en entreprise, on rencontre bien souvent ce genre de situation : On essaye de se mettre d'accord sur la spécification d'une nouvelle fonctionnalité, et quand vient le moment d'en définir la date de livraison, on se voit répondre “Dès que possible”. Cela peut sembler la réponse la plus honnête, la plus simple à comprendre de tous et la plus facile à gérer ; mais en fait il s'agit souvent d'un pis-aller qui démontre que le projet n'est pas réellement pris en main.

Quand on demande un développement ASAP (as soon as possible), on abdique sur tous les facteurs qui définissent un projet :

  • La définition exacte du projet n'a pas été faite correctement. On sait bien qu'on n'a pas pris le temps de réfléchir à tous les cas limites, à penser à toutes les situations. On sait − mais on ne le dit pas ouvertement − que les développeurs devront affronter tous ces culs-de-sac fonctionnels au fur et à mesure qu'ils se casseront les dents dessus, ce qui empêche d'apporter une quelconque valeur aux estimations qu'ils peuvent faire de leurs développements.
  • À partir du moment où la seule contrainte exprimée est celle du temps passé sur le projet, on accepte implicitement que des raccourcis soient fait pour atteindre l'objectif au plus vite. Un aspect en pâtira forcément, qu'il s'agisse de la qualité générale de la réalisation, de la maintenabilité du code, des tests, du débuggage, ...
  • À l'inverse, l'absence de deadline réaliste autorise les développeurs à se lancer dans des développements inutiles (je ne parle même pas de ceux qui se tournent les pouces). On arrive ainsi à des situations où on découvre au bout de 2 semaines que le développement “ASAP” aurait pu durer 4 jours si on avait pris le temps de dimensionner et budgéter le projet correctement ; mais si on en fait la remarque au(x) développeur(s), on obtient une réponse du genre «Ah, moi j'estime que tout ce que j'ai fait était nécessaire pour que le projet fonctionne correctement. Il fallait me prévenir si c'était plus urgent que ça !».

Lire la suite...

samedi 19 septembre 2009

Et si Gordon Ramsay était informaticien ?

Depuis quelques temps je ne rate pas un épisode de l'émission Cauchemar en cuisine, qui est diffusée sur plusieurs chaînes télévisées françaises de la TNT ou du câble.

Le concept de cette émission est assez simple : Gordon Ramsay, un chef cuisinier écossais renommé, vient en aide à des restaurateurs au bord de la faillite. Là où ça devient amusant, c'est que Gordon n'a vraiment pas sa langue dans sa poche ; il n'hésite pas à s'énerver très fort quand il le faut, pour faire prendre conscience aux gens qu'il sont sur la mauvaise voie.
Bon, la traduction française a tendance à édulcorer son langage. Ainsi, la phrase «I will smash this plate on your fuking head» est devenu «Je vais casser cette assiette sur ta tête de bois»...

Au fil des épisode, on peut voir des cuisiniers sans talent, des gérants à l'égo stratosphérique, des restaurants complètement vides, des engueulades à côté des clients, ...
Gordon goûte les plats, regarde comment fonctionne l'organisation du personnel, étudie les comptes financiers. Il met ensuite les responsables − le propriétaire, le gérant de salle, le chef cuisinier − face à leurs lacunes, leurs faiblesses, leur fainéantise, leur désorganisation. Quand les problèmes ont été compris (au bout de quelques bonnes engueulades hautes en couleur), il met en place un plan de bataille qui permet de remonter les résultats du restaurant.

Il utilise souvent les mêmes recettes (au sens figuré du terme, désolé je n'ai pas pu m'en empêcher) d'un restaurant à l'autre, mais à chaque fois avec des résultats différents. Ce qui est vraiment intéressant, c'est qu'il met en application des principes qui tiennent plus de l'entrepreneuriat que de la restauration. Il y a beaucoup d'inspiration à trouver là pour une équipe technique.

L'étude de marché

À chaque fois, Gordon fait un petit tour dans la ville où il est tombé. Il fait attention aux autres restaurants existants, et essaye de trouver le type de restauration qui n'est pas représenté. Il regarde aussi la clientèle existante (ou ce qu'il en reste), et à partir de tout ça il invente un nouveau visage au restaurant pour lui faire trouver une nouvelle clientèle.
Cette nouvelle identité est souvent mal vécue par les patrons qui voient leurs habitudes remises en question. Le menu est complètement revu (je vais y revenir), le restaurant est redécoré, parfois même renommé. Mais ce nouveau positionnement est gagnant, et l'augmentation des bénéfices lui donne toujours raison.

Lire la suite...

lundi 14 septembre 2009

Pas de productivité miracle

Il existe un grand nombre de soit-disant "méthodes", qui sont censées nous enseigner tout ce que nous avons besoin de savoir pour augmenter notre productivité de manière incroyable. Qu'ils s'agisse de livres ou de sites web, vous les trouverez sous des noms plus tentants les uns que les autres : "101 trucs pour booster votre productivité", "Travaillez à 400%", "Soyez 10 fois plus productif".

Évidemment, il existe des vraies méthodes d'organisation personnelle qui permettent d'augmenter notre efficacité et donc notre productivité, comme la très connue méthode GTD.

Il faut comprendre la différence entre ces deux approches.
Les méthodes d'organisation personnelle offrent des outils qui aident à faire les bons choix dans le traitement des tâches qui nous incombent. Elles se focalisent principalement sur la définition et l'identification des priorités, et le tri rapide des tâches. Leur efficacité est réelle, même si elle est inversement proportionnelle à l'organisation "naturelle" de la personne qui en applique les principes.

A contrario, les méthodes de "productivité miracle" font miroiter la possibilité de traiter plus de tâches sur la même période de temps.
Cela peut être atteint en agissant sur deux fronts : traiter les tâches plus rapidement, et réduire les périodes non consacrées au travail directement productif. C'est très honorable, et au final assez naturel quand on essaye d'optimiser notre productivité. Mais espérer multiplier sa productivité par 3, 4 ou 10, semble plutôt naïf.

  • La plupart du temps, quand on traite une tâche on le fait avec une efficacité relativement satisfaisante. Même s'il est toujours possible d'améliorer les choses (par exemple en supprimant les éléments perturbateurs, afin d'améliorer la concentration), il est souvent vain de vouloir traiter une tâche deux fois plus vite que d'habitude. On est surtout sûr de la traiter deux fois moins bien.
  • Réduire le temps non productif est une très bonne idée. Une partie de ce temps est nécessaire et relativement incompressible : tout le temps qu'on passe en formation (à en donner et à en recevoir), à réfléchir à des spécifications, à encadrer son équipe, ...
  • Reste le temps pendant lequel on se gratte la tête, on joue avec des trombones, on touille son café, on va lire le journal au toilettes... Hum. Même en imaginant que vous perdiez ainsi 2 heures par jour (grosse feignasse !), et en espérant diviser ce temps par trois − ce qui constitue déjà un bonne optimisation − vous ne gagnerez que 40 minutes par jour. On est loin de la productivité décuplée !

Donc oubliez les solutions miracles. Faites votre boulot posément et dans le bon ordre. Identifiez les urgences. Déléguez.

- page 1 de 5