Yes, I'll add the report to the bug ticket. As for the msvcr71.dll, the particular module I'm using was apparently compiled with VS2005, but I'm currently unable to rebuild it with VS2008 because I don't have the MSSQL developer headers, etc. So, in an ideal world, I'd compile the module myself and strip the manifest, or apply the manifest-stripping patch and then just compile the module, and the msvcr71.dll step would be unnecessary. (Well, in an IDEAL world I'd not have all these problems because I'd be running on MySQL, OpenMPI, and a Linux HPC ;)<br>
<br>-nick<br><br><br><div class="gmail_quote">On Fri, Oct 16, 2009 at 6:31 AM, M.-A. Lemburg <span dir="ltr"><<a href="mailto:mal@egenix.com">mal@egenix.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
<div class="im">Nick Touran wrote:<br>
> I've made enough progress to get my setup working! I attempted to apply the<br>
> patch and recompile the packages that complained but got in too deep while<br>
> compiling matplotlib on windows (I don't have admin privileges and can't<br>
> install the prereqs) so I dug deeper.<br>
><br>
> I found this: <a href="http://blog.kalmbachnet.de/?postid=80" target="_blank">http://blog.kalmbachnet.de/?postid=80</a> which suggests removing<br>
> the publicKeyToken attribute from the manifests to force local DLLs. This<br>
> would possibly give the same effect as not embedding the manifests in the<br>
> first place using the patch. So I went in, using VS2008, and removed this<br>
> attribute from the embedded manifests in python26.dll, python.exe, and the<br>
> manifest file in C:\python26. I also copied msvcm90.dll, msvcp90.dll, and<br>
> msvcr90.dll from the 9.0.21022.8 folder in c:\Windows\WinSxS into<br>
> c:\Python26 W.ith that, matplotlib started working, but pymssql still did<br>
> not.<br>
<br>
</div>Thanks for your report. Could you add a summary to the ticket I<br>
mentioned below ?<br>
<div class="im"><br>
> I then renamed _mssql.pyd to _mssql.dll so that VS2008 could recognize the<br>
> manifest, removed the publicKeyToken attribute, and renamed it back to<br>
> _mssql.pyd, but it still complained. Finally, using depends.exe from the<br>
> internet, I noticed msvcr71.dll was required on my local machine, so I tried<br>
> copying it over to the remote machine, into the site-packages folder. Bam.<br>
> It worked. So while I don't really consider this a solution, it definitely<br>
> worked for what I needed. Any other 3rd party modules that complain in the<br>
> future in my weird xcopy-deployment will undergo manifest-stripping via<br>
> VS2008 and other dependency checking via depends.exe. Yay.<br>
<br>
</div>What I don't understand in your description is why the msvcr71.dll<br>
was needed. It's usually not a good idea to mix VC runtime in a single<br>
process and since Python requires the VC 90 DLLs, it's likely<br>
safer to recompile the extension in question using Python 2.6 and<br>
VS 2008.<br>
<div><div></div><div class="h5"><br>
> -nick<br>
><br>
> On Mon, Oct 12, 2009 at 2:41 PM, M.-A. Lemburg <<a href="mailto:mal@egenix.com">mal@egenix.com</a>> wrote:<br>
><br>
>> Nick Touran wrote:<br>
>>> It is indeed a pain. I would really like a work-around. Matplotlib is<br>
>>> supposed to be immune to this nowadays but it's not. Nor are some other<br>
>>> third-party modules. Did they break with the new release? (2.6.3?)<br>
>><br>
>> The main problem appears to be that the the MS VC9 compiler defaults<br>
>> to embedding a dependency on the MS VC90 CRT DLL into extension modules:<br>
>><br>
>>  <dependency><br>
>>    <dependentAssembly><br>
>>      <assemblyIdentity type="win32" name="Microsoft.VC90.CRT"<br>
>> version="9.0.21022.8"<br>
>> processorArchitecture="x86"<br>
>> publicKeyToken="1fc8b3b9a1e18e3b"></assemblyIdentity><br>
>>    </dependentAssembly><br>
>>  </dependency><br>
>><br>
>> Unless you have installed the CRT runtime DLLs installed system-wide,<br>
>> this will require the DLLs to be installed next to the extension<br>
>> module DLL or PYD file... and that even though the Python process<br>
>> itself will already have loaded the DLL from the Python directory.<br>
>><br>
>> A work-around is attached to the ticket as patch.<br>
>><br>
>> Even though a fix for distutils is planned in 2.6.4, this type of<br>
>> problem will pop up for all kinds of software using VC90-based DLLs<br>
>> as plugins, so it's probably better to just install the CRT runtime<br>
>> DLLs in the WinSxS directory using the CRT installers:<br>
>><br>
>> x86:<br>
>><br>
>> <a href="http://www.microsoft.com/downloads/details.aspx?familyid=A5C84275-3B97-4AB7-A40D-3802B2AF5FC2&displaylang=en" target="_blank">http://www.microsoft.com/downloads/details.aspx?familyid=A5C84275-3B97-4AB7-A40D-3802B2AF5FC2&displaylang=en</a><br>

>><br>
>> x86_64:<br>
>><br>
>> <a href="http://www.microsoft.com/downloads/details.aspx?familyid=BA9257CA-337F-4B40-8C14-157CFDFFEE4E&displaylang=en" target="_blank">http://www.microsoft.com/downloads/details.aspx?familyid=BA9257CA-337F-4B40-8C14-157CFDFFEE4E&displaylang=en</a><br>

>><br>
>>> On Thu, Oct 8, 2009 at 1:12 PM, M.-A. Lemburg <<a href="mailto:mal@egenix.com">mal@egenix.com</a>> wrote:<br>
>>><br>
>>>> Nick Touran wrote:<br>
>>>>> Copying my local copy of Python 2.6 to a Windows HPC 2008 system is<br>
>>>> giving<br>
>>>>> dll side-by-side configuration errors for some third-party packages<br>
>>>>> (matplotlib, pyMSSQL, in particular). I understand that there is a<br>
>>>> tradition<br>
>>>>> of Python supporting XCOPY deployment, and would really like to be able<br>
>>>> to<br>
>>>>> just copy my C:\python26 folder to the network drive and have it run on<br>
>>>> the<br>
>>>>> server.<br>
>>>>><br>
>>>>> I got around a related issue (<a href="http://bugs.python.org/issue4566" target="_blank">http://bugs.python.org/issue4566</a>) just<br>
>> by<br>
>>>>> upgrading to 2.6.3 and was able to import socket and mpi4py and<br>
>>>> everything,<br>
>>>>> except matplotlib and pyMSSQL, that is.<br>
>>>>><br>
>>>>> I also understand that if I were to install the MS Visual Studio 2008<br>
>>>>> redistribution package on the server that everything would be fine<br>
>>>> because<br>
>>>>> the modules just can't find the proper C run-time DLL. The problem with<br>
>>>> that<br>
>>>>> is two-fold: I don't have admin rights on the machine and there are<br>
>> over<br>
>>>>> 1000 machines on the cluster and I don't think the admin is going to<br>
>>>> install<br>
>>>>> that on all of them.<br>
>>>>><br>
>>>>> So is there any way to set an environmental variable or something to<br>
>> get<br>
>>>>> these packages to know where to find the proper msvcr90.dll, akin to<br>
>>>> setting<br>
>>>>> LD_LIBRARY_PATH in Linux? Is there another solution?<br>
>>>><br>
>>>> I assume this is related to this new problem:<br>
>>>><br>
>>>>        <a href="http://bugs.python.org/issue4120" target="_blank">http://bugs.python.org/issue4120</a><br>
>>>><br>
>>>> Manifests were meant to solve some of the DLL mess... apparently they<br>
>>>> cause even more grief.<br>
>>>><br>
>>>> --<br>
>>>> Marc-Andre Lemburg<br>
>>>> eGenix.com<br>
>>>><br>
>>>> Professional Python Services directly from the Source  (#1, Oct 08 2009)<br>
>>>>>>> Python/Zope Consulting and Support ...        <a href="http://www.egenix.com/" target="_blank">http://www.egenix.com/</a><br>
>>>>>>> mxODBC.Zope.Database.Adapter ...             <a href="http://zope.egenix.com/" target="_blank">http://zope.egenix.com/</a><br>
>>>>>>> mxODBC, mxDateTime, mxTextTools ...        <a href="http://python.egenix.com/" target="_blank">http://python.egenix.com/</a><br>
>>>> ________________________________________________________________________<br>
>>>><br>
>>>> ::: Try our new mxODBC.Connect Python Database Interface for free ! ::::<br>
>>>><br>
>>>><br>
>>>>   eGenix.com Software, Skills and Services GmbH  Pastor-Loeh-Str.48<br>
>>>>    D-40764 Langenfeld, Germany. CEO Dipl.-Math. Marc-Andre Lemburg<br>
>>>>           Registered at Amtsgericht Duesseldorf: HRB 46611<br>
>>>>               <a href="http://www.egenix.com/company/contact/" target="_blank">http://www.egenix.com/company/contact/</a><br>
>>>><br>
>>><br>
>><br>
>> --<br>
>> Marc-Andre Lemburg<br>
>> eGenix.com<br>
>><br>
>> Professional Python Services directly from the Source  (#1, Oct 12 2009)<br>
>>>>> Python/Zope Consulting and Support ...        <a href="http://www.egenix.com/" target="_blank">http://www.egenix.com/</a><br>
>>>>> mxODBC.Zope.Database.Adapter ...             <a href="http://zope.egenix.com/" target="_blank">http://zope.egenix.com/</a><br>
>>>>> mxODBC, mxDateTime, mxTextTools ...        <a href="http://python.egenix.com/" target="_blank">http://python.egenix.com/</a><br>
>> ________________________________________________________________________<br>
>><br>
>> ::: Try our new mxODBC.Connect Python Database Interface for free ! ::::<br>
>><br>
>><br>
>>   eGenix.com Software, Skills and Services GmbH  Pastor-Loeh-Str.48<br>
>>    D-40764 Langenfeld, Germany. CEO Dipl.-Math. Marc-Andre Lemburg<br>
>>           Registered at Amtsgericht Duesseldorf: HRB 46611<br>
>>               <a href="http://www.egenix.com/company/contact/" target="_blank">http://www.egenix.com/company/contact/</a><br>
>><br>
><br>
<br>
</div></div>--<br>
<div class="im">Marc-Andre Lemburg<br>
eGenix.com<br>
<br>
</div>Professional Python Services directly from the Source  (#1, Oct 16 2009)<br>
<div><div></div><div class="h5">>>> Python/Zope Consulting and Support ...        <a href="http://www.egenix.com/" target="_blank">http://www.egenix.com/</a><br>
>>> mxODBC.Zope.Database.Adapter ...             <a href="http://zope.egenix.com/" target="_blank">http://zope.egenix.com/</a><br>
>>> mxODBC, mxDateTime, mxTextTools ...        <a href="http://python.egenix.com/" target="_blank">http://python.egenix.com/</a><br>
________________________________________________________________________<br>
<br>
::: Try our new mxODBC.Connect Python Database Interface for free ! ::::<br>
<br>
<br>
   eGenix.com Software, Skills and Services GmbH  Pastor-Loeh-Str.48<br>
    D-40764 Langenfeld, Germany. CEO Dipl.-Math. Marc-Andre Lemburg<br>
           Registered at Amtsgericht Duesseldorf: HRB 46611<br>
               <a href="http://www.egenix.com/company/contact/" target="_blank">http://www.egenix.com/company/contact/</a><br>
</div></div></blockquote></div><br>