Re: Transition to Python 3

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, Apr 17, 2018 at 7:08 AM, Nathan Cutler <ncutler@xxxxxxx> wrote:
> Background: Python 2 will be deprecated in 2020. Python 3 has been available
> in all major Linux distros for years.
>
> Of course, Python 2 is *also* available in all major Linux distros, but this
> is not going to be true for much longer. It will be deprecated and
> eventually removed.
>
> Migration, then, is going to happen - it's just a question of "when".
>
> Given that Python 3 is available now, and will be supported for many years,
> as opposed to Python 2 which will be going away and will not be supported,
> the need to migrate our Python code to Python 3 will only become more
> urgent, not less.
>
> Ceph contains the following Python code (please correct me if this list is
> not complete):
>
> Python bindings (already migrated, i.e. Python 3 bindings are available)
> MGR modules (migration in progress; no testing with Python 3, though)
> ceph-volume (migration status: ?)
> ceph-detect-init (migration status: ?)
> ceph-disk (migration status: ?, deprecated, will be removed in Nautilus)
> Python scripts needed for "make check" (migration in progress)
> Python scripts needed for QA/teuthology (migration status: ?)
> Other Python scripts (not packaged)
>
> Ideally this email would spark a discussion on how to perform the
> transition. In my imagination, the transition could go like this:
>
> Mimic - after a "best effort" to migrate, some Python code still runs on
> Python 2, but Shaman has a Python 3 build flavor and teuthology is capable
> of testing in Python 3-only environment.
>
> Nautilus - all remaining packaged Python code has been migrated and
> explicitly runs (and is tested) on Python 3. Python 2 versions of our code
> do not need to be provided or packaged, because all target platforms support
> Python 3. There might still be some Python 2 scripts in the git repo, but
> these are either special cases or for developer use only, and are not
> packaged.

We should clarify what we mean about target platforms supporting
python 3 -- in CentOS for example, python 3 is not in the distro (but
it is available in the EPEL repositories).  I think RHEL 7 has a
similar situation, people need extra repos to get python 3, which
complicates installing Ceph.

I'm not objecting to making the leap (it's better than trying to
support 2 and 3 at the same time!), but let's make sure we understand
consequences for users.

John


>
> Nathan
> --
> To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
> the body of a message to majordomo@xxxxxxxxxxxxxxx
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
--
To unsubscribe from this list: send the line "unsubscribe ceph-devel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [CEPH Users]     [Ceph Large]     [Information on CEPH]     [Linux BTRFS]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux