1 Star 0 Fork 0

huangning2/postgis

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
HOWTO_RELEASE 7.09 KB
一键复制 编辑 原始数据 按行查看 历史
Regina Obe 提交于 2024-09-25 14:13 . Prep for 3.5.0 release
How to release
~~~~~~~~~~~~~~
Date: 2022-09-25
Versioning Scheme
-----------------
*PostGIS*
PostGIS release version is composed by POSTGIS_MAJOR_VERSION,
POSTGIS_MINOR_VERSION and POSTGIS_MICRO_VERSION components, all
set in Version.config.
By default only [POSTGIS_MICRO_VERSION] increments between releases.
Starting at PostGIS 2.1 in development POSTGIS_MICRO_VERSION should have
a "dev" string at the end
[POSTGIS_MINOR_VERSION] is incremented (and MICRO set to 0) when minor
additions have been introduced (one or two functions can be considered
*micro* additions)
[POSTGIS_MAJOR_VERSION] is incremented (and MICRO and MINOR set to 0) when
a dump/reload of existing spatial databases is *REQUIRED* for things
to work or rather *HIGHLY RECOMMENDED* to get new functionalities.
All POSTGIS_MICRO_VERSION that are in branch or trunk should end in dev.
So for example if you just release 2.1.1, then the 2.1 branch should have
POSTGIS_MICRO_VERSION set to 2dev so that the full version is 2.1.2dev.
*Liblwgeom*
Liblwgeom versioning is composed by by LIBLWGEOM_IFACE_CUR,
LIBLWGEOM_IFACE_AGE and LIBLWGEOM_IFACE_REV; all set and documented
in Version.config.
The liblwgeom versioning represents compatibility of the library
within a PostGIS minor version.
Requirements
------------
In order to build a release, you will need to build PostGIS and the
documentation -- that means having the required software:
* For PostGIS:
- PostgreSQL
- GEOS
- Proj
- SFCGAL
- protobuf-c
- GDAL (for raster)
- json-c (for GeoJSON load support)
- git2cl (for ChangeLog generation)
* For the docs:
- xsltproc
- DocBook XSL scripts
- ImageMagic
- DbLatex (for PDF)
Release procedure
-----------------
1. Check access.
- Can edit tickets and milestones on https://trac.osgeo.org/postgis/
- Can commit to upstream git https://git.osgeo.org/gitea/postgis/postgis
- Have SSH to upload.osgeo.org and can write to /osgeo/download/postgis.
- Have SSH to postgis.net and can write to /etc/nginx/sites-enabled/postgis.net.
- Post to https://git.osgeo.org/gitea/postgis/postgis.net/ and get it added to feed
https://planet.postgresql.org/register/new/
- Can alter https://debbie.postgis.net
2. Check greenlight.
- Ensure all bots are green: https://trac.osgeo.org/postgis
- Check no blockers on https://trac.osgeo.org/postgis/roadmap on version you're releasing.
3. Reconcile done & planned.
- Edit NEWS: set release date and check all notable changes have been reported
(extract from git log and trac tickets for milestone).
- Create milestone for next version in Trac.
- Push all the open tickets in Trac milestone to future and Fund Me milestones.
4. Update code.
- Update the README.md to reflect new to be created buildbot badges
(this should only be needed for master release)
- Edit README.postgis and set release date and version.
- Add release notes in doc/release_notes.xml
- Update Version.config to drop the "dev" suffix
- Add the "dev" suffixed version in extensions/upgradeable_versions.mk
and ensure all the previous released minor versions are listed in it
- Commit all changes
- If this is a minor or major release (no branch exists):
$ rel=x.x # replace x.x with minor version (e.g. 2.3)
$ git checkout master; git checkout -b "stable-$rel"; git push -u osgeo stable-$rev
Go to: https://debbie.postgis.net and copy last branch version and make new job
a) Replace PostGIS_* string params with new version
b) Replace repository url with new branch repo url
c) Update the PostGIS_trunk by updating the PostGIS_* string params
Go to: https://trac.osgeo.org/postgis/ edit the matrix to reflect new branch
5. Publish release
- Check that bots are still green on https://trac.osgeo.org/postgis
- Tag branch:
$ rev=x.x.x # replace x.x.x with micro version (e.g 2.3.1)
$ git tag -a $rev -m "Tagged release $rev"
- Push the tag:
$ git push osgeo --tags
- Check if debbie's PostGIS_Make_Dist job completes successfully:
https://debbie.postgis.net/job/PostGIS_Make_Dist/
- If debbie job succeeds:
- Download tar ball from http://postgis.net/stuff/
$ wget http://postgis.net/stuff/postgis-${rev}.tar.gz .
- Test generated tarball (including extension upgrade)
- Verify documentation have been published to https://postgis.net/stuff
(this sometimes takes sometime so wait 15 minutes)
- Download pdf, epub and doc-html files from http://postgis.net/stuff/
$ wget postgis.net/stuff/doc-html-${rev}.tar.gz
$ wget postgis.net/stuff/postgis-${rev}.{pdf,epub}
- If debbie job fails:
- Create the tarball locally:
$ sh make_dist.sh $rev
- Upload md5 file to https://postgis.net/stuff:
$ scp postgis-${rev}.tar.gz.md5 debbie.postgis.net:/var/www/postgis_stuff
- Create the pdf and epub files:
$ make -C doc/ pdf epub
- Create the doc-html-${rev}.tar.gz file
( check how ci/debbie/postgis_make_dist.sh does it )
- Copy tarball to ssh://upload.osgeo.org/osgeo/download/postgis/source
$ scp postgis-${rev}.tar.gz upload.osgeo.org:/osgeo/download/postgis/source
- Copy pdf, epub and doc-html files to ssh://upload.osgeo.org/osgeo/download/postgis/docs
$ scp doc-html-${rev}.tar.gz \
postgis-${rev}.epub \
postgis-${rev}.pdf \
upload.osgeo.org:/osgeo/download/postgis/docs/
- PostGIS doc release versioned doc - https://postgis.net/documentation/
- On postgis.net server, change /etc/nginx/sites-enabled/postgis.net (Versionless URL line )
- nginx -t #to confirm you didn't break the config
- service nginx reload
Verify the documentation is up to date (might need to change the nginx config)
- Post on website:
- https://git.osgeo.org/gitea/postgis/postgis.net/src/branch/website/config.toml#L155
Fix latest version pointers.
- https://git.osgeo.org/gitea/postgis/postgis.net/src/branch/website/content/news
a) create a new Post for current year making sure the page name starts with mm-dd
Since hugo move, the mm-dd isn't absolutely necessary anymore
as it uses the slug or title and date to determine the permalink. But for now lets keep the same convention.
b) commit and wait 5 minutes to see changes on website
6. Spread the word
- Announce on e-mail, including MD5 checksum in the body of the email
- postgis-users@lists.osgeo.org
- postgis-devel@lists.osgeo.org
- discuss@lists.osgeo.org
- pgsql-announce@postgresql.org (no longer accepts direct posts) need to log in and post https://www.postgresql.org/account/edit/news/
- david@fetter.org to be included in Weekly news
- External web sites
- Wikipedia https://en.wikipedia.org/wiki/PostGIS
- Wikidata https://www.wikidata.org/wiki/Q1569955
- Twitter
This should automatically happen as a result of posting to PostGIS website since Planet PostGIS and Planet PostgreSQL both autotweet.
7. Start new development cycle
- Update Trac and make old Milestone as completed
- Push the revision number forward (see Versioning Scheme)
- Remove the "dev" suffixed version from extensions/upgradeable_versions.mk
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/huangning2/postgis.git
git@gitee.com:huangning2/postgis.git
huangning2
postgis
postgis
master

搜索帮助