• Resolved dan_1

    (@dan_1)


    Thoughts on the below message? Happens only when WP ecommerce plugin is active. If I deactivate and delete the plugin, the error goes away. Thanks!

    Fatal error: WPSC_Countries::get_countries(): The script tried to execute a method or access a property of an incomplete object. Please ensure that the class definition "WPSC_Data_Map" of the object you are trying to operate on was loaded _before_ unserialize() gets called or provide a __autoload() function to load the class definition in /home/content/p3nexnas05_data03/62/2100362/html/wp-content/plugins/wp-e-commerce/wpsc-includes/wpsc-countries.class.php on line 462

    Fatal error: WPSC_Countries::_dirty(): The script tried to execute a method or access a property of an incomplete object. Please ensure that the class definition "WPSC_Data_Map" of the object you are trying to operate on was loaded _before_ unserialize() gets called or provide a __autoload() function to load the class definition in /home/content/p3nexnas05_data03/62/2100362/html/wp-content/plugins/wp-e-commerce/wpsc-includes/wpsc-countries.class.php on line 1142

    https://www.ads-software.com/plugins/wp-e-commerce/

Viewing 15 replies - 46 through 60 (of 82 total)
  • Hi Paula,

    The short answer is yes, but it might take a little patience if you haven’t done this before.

    You need to go into your GoDaddy file manager and rename a file.

    1. Get to your GoDaddy file manager.
    2. Find the top directory for your web site, it might be something like “html”
    3. Go into that directory and find the directory named “wp-content”
    4. Go into that directory and look for the file named ‘object-cache.php’
    5. Using your file manager, rename ‘object-cache.php’ to xxx-object-cache.php’

    That will stop the object cache from being loaded on your site, and should make sure site 100% usable. I’m sure the WP-eCommerce team would do anything reasonable to make their product work, even disable functionality. I am not sure there is much that they will be able to do. But I will keep looking at the code and if a code change or a workaround can be developed that let’s the GoDaddy APC implementation work i will post a note here so everyone will know about it.

    Based on my observations this issue is something 100% GoDaddy configruation specific. In the past I have been unable to work through my client’s issues with GoDaddy WordPress hosting, so I have moved their sites elsewhere. I am reaching out to them again for some help, but in the past they have not been very forthcoming about what they are doing under the hood. I can’t say that I am very hopeful that they will help this time.

    jeff

    My client is using a MediaTemple VPS for hosting and getting the same error, so it’s not just a Godaddy issue.

    Renaming the object-cache.php file worked. The suggested code fixes did not work for me.

    The code fix only address the object cache issue. The other, possibly APC related, issue still remains.

    Is your site also using APC? If so can you tell me the version?

    Jeff

    The server is using the latest version of APC: 3.1.13

    A quick correction: the client’s site is hosted on Mediatemple’s Premium WordPress Studio, not a VPS.

    Thanks for replying!

    jwheck,

    If you want to try a little code change and restore the fixed object-cache.php, here is something I am testing.

    plugins\wp-e-commerce\wpsc-includes\wpsc-data-map.class.php

    find the function “confirm_data_ready()”
    change the line that reads

    $this->_map_data = get_transient( $this->_map_name );

    to

    $this->_map_data = false;

    Not sure why, but it seems to address the issue on one of the sites that is having the problem.

    -jeff

    Thank you, Jeff! It seems to have done the trick! Let’s hope it stays fixed.
    Paula

    Jeff,

    That seemed to work for a little bit until I refreshed a few times, then I got the same error again.

    ok, did you happen to click the flush cache button in the check up tool?

    I had not since making the “$this->_map_data = false;” change.

    I clicked it and it had no effect.

    jwheck,

    any chance you can turn on WP_DEBUG, enable the logging and capture the debug.log for me. The other site has the error coming from the get_transient call commented out above. I want to see if an error is originating from a different place in your installation. Maybe comparing the two stack traces will give us a clue as to a root cause.

    Jeff

    I have posted a summary of my work on this issue up to this point. Included is what may be a viable solution (it’s a work-around) to the APC object cache behavior.

    https://www.pyebrook.com/diagnosing-a-wp-ecommerce-error-on-godaddy-hosting-with-php-apc/

    After some discussion i’ll post back a note summarizing the next step.

    jeff

    I’m trying to play catchup tonight, I’m sorry I disappeared I had a small out of town crises to attend to. Yes I use Godaddy and its their wordpress specific plan. My site appears to be working as it should – thank you.

    tmjea, thanks for making your site available for us to diagnose the issue. It was indeed very helpful.

    For everyone concerned the link from my site above has the more technical explanation for the issues and how we isolated them. The non-technical key points are as follows.

    (1) You can make the problem go away by removing the object-cache.php in your site’s wp-content directory. But you won’t have to do this because of the points below.

    (2) There is something broken or misconfigured in some installations oF APC (a common web server component) that crashes when a value that was saved to APC in the default format is recalled. We are going to change the format of how WP eCommerce saves the item so it will be stored to a different format to avoid the issue. There is still a likelihood that you may encounter the error with WordPress itself, or with different plugins.

    (3) There is also a bug in the object-cache.php that GoDaddy and others use on their web sites. The bug causes the APC cache to be unavailable when doing any administrative work on the web site. That means that if you update something like post comments, or in the case of WP eCommerce, product inventory, the update may not show for the visitors to your site.

    This bug has been reported to the plugin author, but the plugin hasn’t been updated in several years and we don’t know if it will be.

    You can help out yourself, other sites and your hosting provider by opening an support incident and report the broken object-cache.php plugin. The fix is a one line change, and is noted in the blog post https://www.pyebrook.com/diagnosing-a-wp-ecommerce-error-on-godaddy-hosting-with-php-apc/.

    Jeff

    Hi Jeff,

    Just to follow up the error came back. Seems to be in the morning more often than other times. No other clues. If I disable the WP eCommerce plugin, the home page returns but every other page throws an error. We are not even using this plug in! This morning it showed up and I was able to clear it with a WP cache clear.

    Any other thoughts?

    Hi Paul,

    What is your configuration at this time?

    Is the object-cache.php still in place?

    Are you running any of the patches we have been discussing in this thread or at https://www.pyebrook.com/diagnosing-a-wp-ecommerce-error-on-godaddy-hosting-with-php-apc/.

    Our current thinking is that we have established an APC error that is a result of either a hosting provider misconfiguration or a bug in the APC component that is part of the PHP distribution.

    We are reviewing a patch to WP eCommerce that will make WP eCommerce resistant to the problem. But other plugins, or even WordPress itself would still be susceptible to the issue.

    jeff

Viewing 15 replies - 46 through 60 (of 82 total)
  • The topic ‘Fatal Error WPSC_Countries’ is closed to new replies.