Estou aprendendo a criar RPMs para meus próprios pacotes. Normalmente eu posso fazer tudo enquanto estiver logado em minha própria conta, mas as instruções sobre como fazer RPMs sempre parecem querer que você use alguma outra conta.
Um tutorial que segui utilizado rpm-build
e rpmdevtools
. O rpmdev-setuptree
, por exemplo, cria um diretório rpmbuild/
no meu diretório inicial e (não o diretório atual como eu esperava). As instruções também sugeriram que eu criasse uma build
conta separada. Isso parece excessivo e dificulta o gerenciamento de arquivos entre essa conta especial e a conta em que estou desenvolvendo.
A documentação oficial do fedora usa os pacotes fedora-packager
e fedora-review
e então prossegue para que você se adicione ao grupo de simulação . Mais uma vez, sugere:
Você também pode criar um usuário separado e usá-lo para fazer o desenvolvimento RPM. Certifique-se de que o usuário faça parte do grupo simulado e insira o
fedora-packager-setup
comando.
Ambas as instruções incentivam a criação de um RPM em uma conta separada.
Por que é isso? Minha reação automática é tentar contornar isso de alguma forma por conveniência. Que problemas posso enfrentar ao criar RPMs da minha conta normal?
O princípio geral ao empacotar é que você não deve fazer suposições sobre o sistema que não estejam declaradas na configuração do empacotamento. Isso inclui muitas coisas: os pacotes necessários para a construção, os pacotes necessários para a execução, as contas (usuário ou grupo) necessárias, as permissões necessárias, etc. sistema, mas não em um ambiente limpo. E mesmo que tenha compilado, pode não ser instalado. E mesmo que tenha instalado, pode não funcionar como esperado.
Dessa forma, as distros podem usar sistemas de compilação automatizados, onde um mantenedor só precisa fazer o upload da configuração do pacote e o sistema de compilação faz todo o resto. Os pacotes construídos dessa maneira são, obviamente, muito mais confiáveis. Como tudo o que eles exigem está especificado na embalagem, é muito mais improvável que instalá-los quebre o sistema de um usuário.
Eu não leio a documentação do Fedora dessa forma; para mim, ele diz que, se você quiser , pode usar uma conta separada para fazer seu trabalho de empacotamento e explica o que você precisa fazer para que isso funcione. Não diz que você tem que fazer isso, nem mesmo encoraja você a fazê-lo.
Eu uso minha conta principal para meu trabalho de embalagem. No entanto, garanto que meus requisitos de compilação estão completos executando
mock
compilações (e, claro, compilando em Koji ou nosso equivalente interno).Você pode dizer ao rpmbuild onde seus arquivos estão usando
--define '_builddir <Your_Root>'
Você não precisa executá-lo com uma conta diferente, embora eu ache que seja uma boa prática fazê-lo. Espero que isso seja útil. Era.