Mysql
 sql >> डेटाबेस >  >> RDS >> Mysql

Godaddy पर MySQL और Entity Framework का उपयोग करते हुए सुरक्षा अपवाद

अजीब एक। GoDaddy साझा-होस्टिंग ASP.NET ऐप्स मध्यम ट्रस्ट के तहत निष्पादित होते हैं, और perf काउंटर निर्माण के लिए शायद पूर्ण विश्वास की आवश्यकता होती है, लेकिन perf काउंटर निर्माण वह नहीं है जो यहाँ विफल हो रहा है। (और अगर यह विफल हो जाता है, तो यह प्रचारित नहीं होगा क्योंकि mySQL क्लाइंट कोड द्वारा perf coutner निर्माण अपवादों को निगल लिया जाता है)।

इसके बजाय, यह perf काउंटर निर्माण से पहले, एक स्ट्रिंग संसाधन तक पहुँचने का प्रयास करने में विफल हो रहा है। MySQL क्लाइंट के Resources.Designer.cs में कोड की इस पंक्ति के साथ विफलता है:

return ResourceManager.GetString("PerfMonCategoryName", resourceCulture)

कठिनाई के बढ़ते क्रम में कोशिश करने के लिए कुछ चीजें:

  1. सुनिश्चित करें कि आपके ऐप की बिन निर्देशिका में MySQL क्लाइंट DLL हैं और आप क्लाइंट DLL को GoDaddy के GAC से लोड करने का प्रयास नहीं कर रहे हैं। यदि आप इससे बच सकते हैं तो कभी भी GoDaddy द्वारा प्रदत्त बायनेरिज़ पर निर्भर न रहें!

  2. EN-US संस्कृति पर स्विच करें ताकि क्लाइंट को किसी अन्य संसाधन DLL की तलाश में न जाना पड़े, और देखें कि क्या समस्या दूर हो जाती है।

  3. अपने ऐप की बिन निर्देशिका में बाइनरी वितरण से डीएलएल की प्रतिलिपि बनाने के बजाय, स्रोत कोड से .NET क्लाइंट बनाएं। यह इस तरह की समस्याओं को डीबग करना आसान बना देगा क्योंकि MySQL कोड ब्लैक बॉक्स नहीं होगा। और, एक चुटकी में, आपको समस्याग्रस्त संसाधन-प्राप्ति कॉल (या हार्ड-कोड लोकेल) को बदलने देगा! :-)

BTW, यदि आप समस्या से बचने की कोशिश करने के लिए अपने कनेक्शन स्ट्रिंग में "उपयोग प्रदर्शन मॉनिटर =गलत" सेट करने का लुत्फ उठाते हैं, तो परेशान न हों। समस्याग्रस्त कोड उस सेटिंग की परवाह किए बिना निष्पादित हो जाता है:

    public PerformanceMonitor(MySqlConnection connection)
    {
        this.connection = connection;

        //// this line is where it bombs
        string categoryName = Resources.PerfMonCategoryName;

        //// this line is affected by connection string setting
        if (connection.Settings.UsePerformanceMonitor && procedureHardQueries == null)
        {
            try
            {
                procedureHardQueries = new PerformanceCounter(categoryName,
                                                              "HardProcedureQueries", false);
                procedureSoftQueries = new PerformanceCounter(categoryName,
                                                              "SoftProcedureQueries", false);
            }
            catch (Exception ex)
            {
                Logger.LogException(ex);
            }
        }
    }


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. SQL क्वेरी के साथ निकटतम अक्षांश/देशांतर खोजें

  2. Laravel's Fluent . का उपयोग करके INSERT IGNORE

  3. एसिंक्रोनस स्लेव्स का उपयोग करके गैलेरा क्लस्टर में हाइब्रिड OLTP/Analytics डेटाबेस वर्कलोड

  4. समान कॉलम वाली दो टेबल या अतिरिक्त कॉलम वाली एक टेबल?

  5. MySQL में SHA1 हैश मान संग्रहीत करना