Construire des produits avec &os;JosephKoshyLe Projet &os;jkoshy@FreeBSD.org$FreeBSD$
&tm-attrib.freebsd;
&tm-attrib.general;
RésuméLe projet &os; est un projet international, collaboratif
et basé sur le volontariat, qui développe un
système d'exploitation portable et de grande
qualité. Le projet &os; distribue le code source de
ses produits avec une licence libérale dans l'intention
d'encourager l'utilisation de son code. Collaborer avec le
project &os; peut aider les organisations à
réduire leur délai de mise sur le marché,
leurs coûts de développement, et améliorer
la qualité de leurs produits.Cet article se penche sur les questions relatives à
l'utilisation du code de &os; dans les appareils informatiques
et les logiciels. Il met en évidence les
caractéristiques de &os; qui en font un excellent
support pour le développement de produits. Cet article
conclut en suggérant quelques bonnes
pratiques pour les organisations qui collaborent avec
le projet &os;.
&trans.a.culot;
Introduction&os; est reconnu aujourd'hui comme un système
d'exploitation hautes performances pour serveurs. Il est
déployé sur des millions de serveurs web et de
machines connectées à internet de part le monde.
Le code de &os; fait aussi partie intégrante de beaucoup
de produits depuis des appareils comme les routeurs
réseau, pare-feux, et dispositifs de stockage, jusqu'aux
ordinateurs personnels. Des parties de &os; ont
également été utilisées dans des
produits commerciaux (voir ).Dans cet article nous nous intéressons au projet &os; en tant que ressource pour
la conception logicielle—une collection de briques de base
et de processus que vous pouvez utiliser pour construire
d'autres produits.Bien que les sources de &os; soient distribuées
librement au public, les organisations ont besoin de
collaborer avec le projet pour pouvoir
pleinement apprécier les bénéfices de ce
travail. Dans les sections suivantes de cet article nous
présentons les moyens efficaces qui existent afin de
collaborer avec le projet, ainsi que les pièges à
éviter.Avertissement au lecteurL'auteur pense que les caractéristiques du Projet
&os; telles que décrites dans cet article sont en
grande partie vraies au moment où cet article a
été conçu et rédigé (2005).
Cependant, le lecteur doit garder en tête que les
pratiques et processus utilisés par les
communautés open-source peuvent changer au cours du
temps, et que les informations contenues dans cet article
devraient donc être considérées comme
étant indicatives plutôt que
prescriptives.Public viséCe document pourrait présenter un
intérêt pour les groupes de personnes
suivants:Les preneurs de décisions dans les
entreprises qui recherchent à améliorer la
qualité de leurs produits, à réduire
leur délai de mise sur le marché, et
réduire leurs coûts de développement sur
le long terme.Les consultants en technologie à la
recherche de bonnes pratiques pour tirer profit de
l'open-source.Les spécialistes de l'industrie
intéressés par la compréhension de la
dynamique des projets open-source.Les développeurs logiciels cherchant
à utiliser &os; et désirant contribuer au
projet en retour.Objectifs de l'articleLa lecture de cet article devrait vous apporter:Une compréhension des buts du Projet &os;
ainsi que de la structure de son organisation.Un aperçu des technologies disponibles dans
le projet.Une compréhension de son modèle de
développement et de ses processus
d'ingénierie.Une compréhension des différences
entre les processus de développement conventionnels
que l'on retrouve chez les éditeurs de logiciels et
ceux utilisés par le projet &os;.Une sensibilisation aux canaux de communication
utilisés par le projet et le niveau de transparence
auquel vous pouvez vous attendre.Une connaissance des moyens optimaux qui existent
pour travailler avec le projet—comment
réduire au maximum les coûts de
développement, améliorer le délai de
mise sur le marché, gérer les failles de
sécurité, et préserver la
compatibilité future de votre produit avec les
évolutions du projet &os;.Structure de l'articleLa suite de l'article est structurée de la
façon suivante: introduit le projet
&os;, présente sa structure organisationnelle, ses
technologies clés et ses processus de
développement. décrit
les moyens de collaborer avec le projet &os;. Les
pièges les plus courants rencontrés par les
sociétés travaillant avec les projets
basés sur le volontariat comme &os; sont
également présentés. conclut.&os; en tant que brique constitutive&os; représente une excellente base sur laquelle
construire des produits:Le source code de &os; est distribué avec une
licence BSD libérale qui facilite grandement son
utilisation dans les produits commerciaux
Mon2005.Le projet &os; a d'excellentes pratiques de
développement qui peuvent être mises à
profit.Le projet offre une transparence exceptionnelle eu
égard à son fonctionnement, permettant aux
companies utilisant son code de planifier efficacement
l'avenir.La culture du projet &os;, héritée du
Groupe de Recherche sur la Science Informatique de
l'Université de Berkeley en Californie
McKu1999-1, encourage le travail de
grande qualité. Certaines fonctionnalités de
&os; sont considérés comme des
références.GoldGab2005 examine avec plus de
détails les raisons commerciales qui justifient
l'utilisation de l'open-source. Les bénéfices que
les sociétés peuvent tirer de l'utilisation de
composants &os; dans leurs produits comprennent un délai
réduit de mise sur le marché, ainsi qu'une
réduction des coûts et des risques liés au
développement.Construire avec &os;Voici quelques utilisations que des
sociétés ont faites de &os;:Comme source de code testé pour des
bibliothèques ou utilitaires.En étant en aval du projet,
les organisations tirent profit des nouvelles
fonctionnalités, corrections de bogues et tests
dont le code en amont bénéficie.En tant que système d'exploitation
embarqué (par exemple, pour un routeur OEM ou un
appareil servant de pare-feu). Dans ce modèle, les
organisations utilisent un noyau &os; adapté ainsi
qu'un ensemble de logiciels appropriés
conjointement avec une couche propriétaire de
gestion de leur appareil. Les OEMs
bénéficient des nouveaux supports
matériels ajoutés par le projet &os; en
amont, ainsi que des tests effectués sur le
système de base.&os; est diffusé avec un environnement de
développement auto-hébergé qui permet
de créer facilement de telles
configurations.En tant qu'environnement compatible &unix; pour les
fonctions de gestion des environnements de stockage et les
appareils réseau, fonctionnant sur un
serveur lame
séparé.&os; fournit les outils nécessaires pour
créer des systèmes d'exploitation
dédiés et des images d'applications. Son
implémentation basée sur une API BSD &unix;
est mature et testée. &os; peut aussi fournir un
environnement de développement croisé stable
pour les autres composants de l'appareil final.En tant que moyen d'obtenir une large base de tests
et du support de la part d'une équipe de
développeurs internationale pour tout ce qui a
trait à la propriété
intellectuelle non critique.Dans ce modèle, les organisations apportent
un ensemble d'infrastructures utiles au projet &os; (voir
par exemple &man.netgraph.3;). L'importante exposition
que le code acquiert aide pour l'identification rapide de
problèmes de performance et de bogues.
L'implication d'excellents développeurs apporte
aussi des ajouts utiles à la base existante, ce
dont l'organisation contributrice bénéficie
également.En tant qu'environnement de développement
autorisant le développement croisé pour des
systèmes embarqués tels que RTEMS et eCOS.Il existe une pléthore d'environnements de
développement très complets dans le
catalogue des &os.numports; applications portées et
empaquetées pour &os;.Comme moyen de fournir une API Unix dans un
système propriétaire par ailleurs,
augmentant ainsi son attractivité pour les
développeurs d'applications.Dans ce cas des parties du noyau &os; et des
applications sont portées pour
tourner conjointement avec d'autres tâches du
système d'exploitation propriétaire. La
disponibilité de l'implémentation d'une API
Unix stable et bien testée
peut réduire l'effort nécessaire pour porter
des applications populaires sur le système
propriétaire. Comme &os; est fournit avec une
documentation de grande qualité concernant ses
mécanismes internes et assure une gestion efficace
des vulnérabilités et des cycles de
développement, les coûts pour se maintenir
à jour sont bas.TechnologiesLe projet &os; supporte un grand nombre de technologies
dont une sélection est présentée
ci-dessous:Un système complet qui peut faire de
l'auto-hébergement croisé pour les
architectures suivantes: alpha (jusqu'à &os;
version 6.X), amd64, ia64, i386, sparc64, powerpc (voir
&man.build.7;).Le support pour les technologies, protocoles et standards
suivants:
ATA, ATAPI,
ATM, Bluetooth,
CAM, CardBus,
DHCP, DNS,
EISA,
Ethernet, FDDI,
Fibre Channel, GPIB, IEEE 1394, IPv4,
IPv6, IPSEC,
IPX, ISDN,
MAC, NIS,
NFS, OpenSSH, OPIE,
PAM, PCI,
PCMCIA, POSIX,
PnP, RAID,
RPC, SATA,
SCSI, SMB,
TCP, USB,
VESA, VLAN,
VLB,
WebNFS.Un noyau modulaire permettant le traitement
symétrique multiprocesseurs, avec chargement
possible de modules noyau et un système de
configuration facile à utiliser.Le support pour l'émulation de
Linux et des binaires SVR4 à
vitesse quasi-native et le support pour les pilotes
réseau Windows
(NDIS).Des librairies pour de nombreuses tâches
liées à la programmation: archivage, support
FTP et HTTP, support des processus légers en plus
d'un environnement de programmation
POSIX.Des dispositifs de sécurité
avancés : Mandatory Access Control (&man.mac.9;),
jails (&man.jail.2;), ACLs, ainsi que
le support d'un dispositif cryptographique au niveau
noyau.Des caractéristiques réseau
avancées : dispositifs pares-feu, gestion de Qos,
communications TCP/IP hautes performances avec support de
nombreuses caractéristiques
avancées.Le système Netgraph (&man.netgraph.4;)
présent dans le noyau &os; permet à des
modules noyau de gestion des communications réseau
d'être interconnectés de manière
flexible.Le support pour des technologies de stockage
avancées: fibre, SCSI, RAID
logiciel et matériel, ATA et
SATA.&os; est capable de gérer plusieurs
systèmes de fichiers différents, et son
support natif du système de fichiers UFS2 autorise
les soft updates, les
sauvegardes instantanées, ainsi que les
systèmes de fichiers très volumineux (16TB
par système)
McKu1999.Le système GEOM
(&man.geom.4;) présent dans le noyau &os; permet de
composer de manière flexible des modules noyau
dédiés à la gestion du
stockage.L'accès à plus de &os.numports;
applications portées, qu'elles soient commerciales
ou open-source, gérées grâce à
la collection des portages de &os;.Structure organisationnelleLa structure organisationnelle de &os; n'est pas
hiérarchique.Il existe essentiellement deux types de contributeurs
à &os;, les utilisateurs de &os;, et les
développeurs qui ont les droits en écriture
(connus sous le terme committers dans
notre jargon) et peuvent modifier les sources.Il existe plusieurs milliers de contributeurs dans le
premier groupe, la vaste majorité des contributions
à &os; proviennent de personnes faisant partie de ce
groupe. Les droits de commit
(droits d'accès en écriture) sont
accordés aux personnes qui contribuent au projet de
manière récurrente. Ces droits viennent avec
des responsabilités supplémentaires, et les
nouveaux committers se voient
attribuer des mentors pour les aider à apprendre les
bases.La résolution des conflits est assurée
par une équipe (Core Team) de neuf
membres qui est élue par le groupe des
committers.Les committers ne sont pas
employés par &os;. Il est exigé de la part des
committers qu'ils prennent la
responsabilité des changements qu'ils introduisent dans
le code. Le Guide du Committer
&os; ComGuide documente les
règles et responsabilités des
committers.Le modèle de projet de &os; est examiné en
détails dans Nik2005.Les processus de développement des versions
de &os;Les processus de développement des versions de
&os; jouent un rôle majeur en assurant que les versions
qui sont délivrées sont de grande
qualité. À n'importe quel moment que l'on
considère, les volontaires de &os; assurent le
développement de plusieurs branches de code ():Les nouvelles fonctionnalités et le code
expérimental sont incorporés sur la branche
de développement, aussi connue sous le nom de
branche -CURRENT.Les branches -STABLE
représentent les lignes de code qui sont reprises
de la HEAD à des intervalles de temps
réguliers. Seul le code testé est
autorisé sur une branche -STABLE. Les nouvelles
fonctionnalités sont autorisées une fois
qu'elles ont été testées et
stabilisées sur la branche -CURRENT.Les branches -RELEASE
sont maintenues par l'équipe sécurité
de &os;. Seuls les correctifs de bogues pour les
problèmes critiques sont autorisés sur les
branches -RELEASE.Les lignes de code sont maintenues aussi longtemps qu'il
existe des utilisateurs et des développeurs qui s'y
intéressent.Les architectures machine sont groupées en
niveaux. Les architectures de premier niveau
(Tier 1) sont entièrement
supportées par l'équipe en charge des versions
et l'équipe sécurité. Les architectures
de second niveau (Tier 2) sont
supportées dans la mesure du possible, et les
architectures expérimentales représentent le
Tier 3. La liste des
architectures supportées est incluse dans la
documentation &os;.L'équipe en charge des versions publie une feuille de route pour les
futures versions de &os; sur la page web du projet. Les dates
qui sont mentionnées sur la feuille de route ne sont
pas des dates butoirs: les versions de &os; sont
délivrées lorsque son code et sa documentation
sont prêts.Les processus de développement des versions de &os;
sont décrits dans
RelEngDoc.Collaborer avec &os;Les projets Open-source tels que &os; offrent un code de
très grande qualité Cov2005.
Des études ont examiné les effets de la
disponibilité du code source sur le développement
logiciel Com2004.Alors que l'accès à du code source de
qualité peut réduire les coûts initiaux de
développement, les coûts liés à la
gestion des changements deviennent prédominants par la
suite. Comme les environnements informatiques changent au fil
du temps et que de nouvelles failles de sécurité
sont découvertes, votre produit lui aussi a besoin de
changements et d'adaptations. Utiliser du code open-source se
conçoit plus comme un processus continu dans le
temps que comme quelque chose de ponctuel. Les
meilleurs projets avec lesquels collaborer sont ceux qui sont
actifs, c'est-à-dire ceux qui ont
une communauté active, des objectifs clairs et des
méthodes de travail transparentes.&os; possède une communauté
active de développeurs gravitant autour du projet.
Au moment de l'écriture de cet article, il existe
plusieurs milliers de contributeurs vivant sur tous les
continents peuplés de la planète et plus de
300 personnes possédant les droits d'accès aux
dépôts des sources du projet.Les objectifs du projet &os; sont
Hub1994:De développer un système
d'exploitation de grande qualité pour les
architectures informatiques populaires, etMettre notre travail à la disposition de
tous sous couvert d'une licence libérale.&os; bénéficie d'une culture ouverte et
transparente. Quasiment toutes les discussions au sein du
projet se font par courrier électronique, sur les
listes publiques
qui sont aussi archivées pour la
postérité. Les règles et pratiques du
projet sont
documentées et maintenues en utilisant un
système de gestion de versions. Participer au projet
est ouvert à tous.Comprendre la culture &os;Afin de pouvoir travailler de manière efficace avec
le projet &os;, vous devez comprendre la culture qui
règne au sein du projet.Les projets menés par des volontaires fonctionnent
avec des règles différentes de celles
utilisées par des organisations commerciales. Une des
erreurs récurrentes faite par les entreprises
lorsqu'elles s'aventurent dans le monde de l'open-source est
de sous-estimer ces différences.MotivationLa plupart des contributions à &os; sont faites
de manière volontaire et aucune rétribution
financière n'entre en jeu. Les facteurs qui motivent
les contributeurs sont complexes, et parmi ceux-ci on peut
citer l'altruisme ou un intérêt pour
résoudre les genres de problèmes que &os;
tente de résoudre. Dans cette environnement,
l'élégance n'est jamais
optionnelleNor1993.La Vision à Long TermeLes origines de &os; remontent à presque vingt
ans dans le passé avec le travail effectué au
Groupe de Recherche en Science Informatique (CSRG) de
l'Université de Berkeley en Californie.Le dépôt
des sources de &os; contient l'historique du
projet depuis sa création, et il existe des
CDROMs qui
contiennent du code plus ancien en provenance du
CSRG.Certains des développeurs originaux
du CSRG sont toujours associés au projet.Le projet met l'accent sur les perspectives à long
terme Nor2001. Un acronyme
fréquemment rencontré au sein du projet est
DTRT qui signifie Do The Right
Thing (Faites les Choses Correctement).Les Processus de DéveloppementLes programmes informatiques sont des outils de
communication: à un certain niveau les programmeurs
communiquent leurs intentions, en utilisant une notation
précise, à un outil (un compilateur) qui
traduit ces instructions en code exécutable.
À un autre niveau, la même notation est
utilisée entre deux programmeurs pour communiquer
leurs intentions.Les spécifications formelles et les documents
d'architecture sont rarement utilisés dans le projet.
Du code clair et bien écrit ainsi que des rapports de
changements () eux aussi bien
écrits sont utilisés à la place. Le
développement de &os; commence par une
ébauche de consensus et en faisant tourner du
codeCarp1996.La communication entre programmeurs est
facilitée par l'utilisation d'un standard commun
concernant le code &man.style.9;.Les canaux de communicationLes contributeurs &os; sont répartis dans le
monde entier. Le courrier électronique (et dans une
moindre mesure, l'IRC) est le moyen de communication
prépondérant au sein du projet.Les meilleures pratiques pour collaborer avec le projet
&os;Nous nous intéressons maintenant à quelques
bonnes pratiques utiles pour tirer profit au maximum de
l'utilisation de &os; pour le développement de
produits.Plan à long termeMettre en place des processus qui simplifient le
suivi du développement de &os;. Par
example:Suivre les changements dans le code source de
&os;Le projet rend la copie de son dépôt
CVS aisée grâce à l'utilisation de
CVSup. Avoir
l'historique complet des sources est utile lors du
déboguage de problèmes complexes et
offre des indications utiles sur les intentions des
développeurs. Utilisez un système de
contrôle de sources efficace qui vous permette
de facilement fusionner les changements entre le code
&os; et votre propre code.La montre une
partie d'un listing annoté du fichier dont le
rapport de changement de la fait référence.
L'origine de chacune des lignes du code source est
clairement affichée. Les listings annotés
montrant l'historique de chacun des fichiers faisant
partie de &os; sont disponibles sur
Internet.Utilisez un observateurNommez un observateur pour
surveiller les développements de &os;, pour
déceler les changements qui pourraient
potentiellement impacter vos produits.Remontez les bogues en amontSi vous détectez un bogue dans le code
&os; que vous utilisez, remplissez un rapport de
bogue. Cette étape permet de faire en
sorte que vous n'ayez pas à corriger le
même bogue la prochaine fois que vous
récupérerez les sources en amont.Tirez profit des efforts portés sur la gestion
des versionsUtilisez du code d'une branche de
développement -STABLE de &os;. Ces branches de
développement sont officiellement
supportées par les équipes en charge des
versions et les équipes sécurité de
&os; et sont constituées de code testé.
Donnez du code pour réduire les
coûtsLa majeure partie des coûts associés
au développement est liée à la
maintenance. En donnant du code non critique au projet,
vous bénéficiez du fait que votre code
aura une diffusion bien plus importante que celle qu'il
aurait eu sans ça. Ceci amène à ce
que plus de bogues et de failles de
sécurité soient éliminés et
que les problèmes de performance soient
identifiés et résolus.
Recevez un soutien efficacePour les produits avec des dates butoirs
rapprochées, il est recommandé d'embaucher
ou de s'attacher les services d'un développeur ou
d'une firme qui a de l'expérience avec &os;. La
&a.jobs; est un canal de communication utile si vous
êtes à la recherche de talents dans le
domaine. Le projet &os; maintient une liste
des consultants et des firmes de consulting
assurant des travaux liés à &os;. Le
Groupe de
Certification &os; propose des certifications
pour la majorité des systèmes
d'exploitation dérivés de BSD.Pour les besoins moins critiques, vous pouvez
demander de l'aide sur les listes de
diffusion du projet. Un guide utile à
suivre si vous souhaitez demander de l'aide est celui de
Ray2004.
Faites de la publicité sur votre
engagementVous n'êtes pas obligé de faire de
la publicité sur votre utilisation de &os;, mais
le faire permet à la fois de vous aider vous mais
aussi le projet.Faire valoir auprès de la
communauté &os; que votre société
utilise &os; améliore vos chances de pouvoir
attirer des personnes talentueuses. Une longue liste de
personnes habilitées à faire du support
sur &os; signifie aussi plus d'échanges
d'idées entre les développeurs. Ceci
permet de construire des fondations plus seines pour
votre futur.Soutenez les développeurs de &os;Parfois la manière la plus directe pour
qu'une fonctionnalité dont on a besoin soit
incluse dans &os; est d'aider un développeur qui
travaille déjà sur un problème
ayant un rapport avec cette fonctionnalité. Ces
aides peuvent prendre plusieurs formes, depuis le don de
matériel jusqu'à des donations
financières. Dans certains pays, les donations
au projet &os; peuvent bénéficier
d'avantages au niveau des impôts. Le projet a un
interlocuteur
dédié pour assister les donateurs.
Le projet maintien également une page web sur
laquelle les développeurs recensent leurs
besoins.Le projet &os; met un point d'honneur à
remercier tous
les donnateurs sur son site web.ConclusionLes objectifs du projet &os; sont de créer et
proposer gratuitement le code source d'un système
d'exploitation de grande qualité. En travaillant avec le
projet &os; vous pouvez réduire vos coûts de
développement et améliorer vos délais de
mise sur le marché dans un certain nombre de
scénarios de développement de produits.Nous avons passé en revue les caractéristiques
du projet &os; qui en font un excellent choix pour faire partie
d'une stratégie produit d'une entreprise. Nous avons
ensuite présenté la culture du projet et
examiné les différents moyens à disposition
pour interagir avec ses développeurs. Cet article
conclut avec une liste des bonnes pratiques qui peuvent
être mises en place par les organisations pour collaborer
avec le projet.Carp1996The
Architectural Principles of the InternetB.CarpenterThe Internet Architecture Board1996Com2004How
is Open-Source Affecting Software
Development?DiomidisSpinellisClemensSzyperskiIEEE ComputerJan/Feb 2004IEEE Computer SocietyComGuideCommitter's
GuideThe &os; Project2005Cov2005Coverity
study on kernel security holes in Linux and &os;Coverity Inc.2005GoldGab2005Innovation Happens
Elsewhere: Open Source as Business StrategyRonGoldmanRichardGabriel2005ISBN 1558608893Morgan-KaufmannHub1994Contributing
to the &os; ProjectJordanHubbard1994—2005The &os; ProjectMcKu1999Soft
Updates: A Technique for Eliminating Most Synchronous Writes
in the Fast FilesystemKirkMcKusickGregoryGangerUSENIX Annual Technical Conference1999McKu1999-1Twenty Years of Berkeley Unix: From AT&T-Owned to
Freely RedistributableMarshall KirkMcKusickOpen
Sources: Voices from the Open Source
RevolutionISBN 1-56592-582-3O'Reilly Inc.1993Mon2005Why you should
use a BSD style license for your Open Source
ProjectBruceMontagueThe &os; Project2005Nik2005A
project model for the &os; ProjectNiklasSaers2005The &os; ProjectNor1993Tutorial
on Good Lisp Programming StylePeterNorvigKentPitman1993Nor2001Teach
Yourself Programming in Ten YearsPeterNorvig2001Ray2004How
to ask questions the smart wayEric StevenRaymond2004RelEngDoc&os; Release
EngineeringMurrayStokely2001The &os; Project