download - Redhat Enterprise Linux 5.9: Yum Updates Not Working: TypeError 'NoneType'

07
2014-07
  • Meengla

    We have a RHEL 5.9 which is refusing to apply updates. For example, if I do a command like: yum update then I get an error like in this thread: https://bugzilla.redhat.com/show_bug.cgi?id=824663 [I don't want to waste any space here by copying/pasting the whole error]. Basically, the error says:

    TypeError: 'NoneType' object is not callable
    

    I have not found a solution yet. I have asked someone in our IT team to check the server's registration with Redhat but it may take a long time to get an answer and I need to have this resolved now.

    Per some online solutions I have tried commenting out line 226/227 from the /init.py file but then I get a warning from Redhat about some kind of violation.

    Now, my immediate needs are to download some RPMs from yum.postgresql.org and so Redhat doesn't need to be involved right now.

    How can I go around this problem?

    Thanks!

  • Answers
  • Meengla

    Never mind-- our IT staff had to re-register the server with the Redhat Network (RHN). Problem fixed! Thanks.


  • Related Question

    linux - What is the difference between yum, apt-get, rpm, ./configure && make install?
  • Saif Bechan

    I am new to Linux and am running CentOS. I have come across four ways to update or install software.

    So far, I've seen:

    • yum install [program]
    • apt-get install [program]
    • rpm -i [program].rpm
    • wget [program].tar.gz -> unpack -> ./configure -> make -> make install

    That last one is a real pain, especially coming from Windows, where a program install is usually one click and a nice install wizard.

    So, my questions are:

    • Why are there so many different ways to do this in Linux?
    • Which one do you recommend using, and why?
    • Are there any other ways to install programs in Linux?

  • Related Answers
  • quack quixote

    These tools all install software into your system, but are working on different levels.

    • ./configure && make install

      Running ./configure && make install builds and installs the libraries or executables directly from the source code.

      The make install step basically just copies the final files into your system. Many sources come with a special make uninstall rule to remove them again, but this is not guaranteed and of course only works as long as you have the configured sources around. Also, this does not take care of required dependencies.

      Often there is only the source code available for a certain package, so this is the only way to go. Also, ./configure usually accepts lots of options allowing you to tailor your package.

      Not being able to find out what software installed which file, and the lack of a reliable way to remove them from the system are major shortcomings of this approach.

    • RPM (Redhat Package Manager)

      rpm installs already configured and compiled software in your system and it also comes with a uninstall to get rid of it again. The packages have to be created by somebody. This person already decided on what features to include and how to best integrate the package into your system layout. It also comes with a list of dependencies.

      Since rpms are used for many distributions there, you will often want to make sure that this rpm was written for your distribution so that install paths, dependencies and other housekeeping things integrate well.

      On Debian systems, the equivalent package format is .deb and the installation and database is handled by the dpkg tool.

    • Yum

      yum is an additional wrapper around rpm. It keeps its own database of rpm files available for your distribution, generally in online repositories. For the stable versions of most distributions all packages inside that database will play well with each other. This database can be searched (e.g. with yum search some_name).

      It will also automatically resolve dependencies for you. Packages (and with some extra help their dependencies) can be easily uninstalled as well.

      On Debian systems, the equivalent repository and dependency-resolution tools are provided by Apt (apt-get and aptitude).

    So to sum it up: if you just want some software try yum first. If it is not available there, you can try to find an existing rpm package. If there is none or you have some special requirements, build from source.

  • marcusw

    Yum are RPM are the same thing except that yum gets the packages from the net automatically and installs them (using rpm -i) in one step. It should be used whenever possible to ease updating. Use rpm only when there is no package to be found by yum, and use the make method only when there is no .rpm package available or you need to change some compile-time options.