c# - 无法启动 dotnet 核心进程。添加工具失败
问题描述
我有一个在 IIS 中运行的 Web 应用程序,它正在使用 .cmd 文件启动一个进程。.bat 文件启动 dotnet 核心应用程序。
这在我的本地安装上运行良好,但是当我在服务器上部署时出现以下错误:
无法将“C:\Users\Default.dotnet\tools”添加到 PATH 环境变量。将此目录添加到您的 PATH 以使用通过“dotnet tool install”安装的工具。
dotnet core 和 dotnet core sdk 已安装。如果我从命令提示符运行 .cmd 文件,它在服务器上运行良好。
我已经搜索并找不到任何有关如何解决此问题的提示。
private void RunMyCmd(string runMyCmdPath)
{
int exitCode;
ProcessStartInfo processInfo;
Process process;
processInfo = new ProcessStartInfo(runMyCmdPath);
processInfo.CreateNoWindow = true;
processInfo.UseShellExecute = false;
// *** Redirect the output ***
processInfo.RedirectStandardError = true;
processInfo.RedirectStandardOutput = true;
processInfo.RedirectStandardInput = true;
process = Process.Start(processInfo);
StreamWriter writer = process.StandardInput;
//string output = reader.ReadToEnd();
writer.WriteLine("a");
// Write the redirected output to this application's window.
// Console.WriteLine(output);
string output1 = process.StandardOutput.ReadToEnd();
string error = process.StandardError.ReadToEnd();
process.WaitForExit();
// *** Read the streams ***
// Warning: This approach can lead to deadlocks, see Edit #2
exitCode = process.ExitCode;
if (exitCode != 0)
errorLogger.Error(string.Format("RunMyCmd: ExitCode({0}) - {1}", exitCode, error));
process.Close();
}
编辑:.cmd 文件代码:
@echo off
rem switch to on to test
for /f "tokens=2 delims==" %%a in ('wmic OS Get localdatetime /value') do set "dt=%%a"
set "YY=%dt:~2,2%" & set "YYYY=%dt:~0,4%" & set "MM=%dt:~4,2%" & set "DD=%dt:~6,2%"
set "HH=%dt:~8,2%" & set "Min=%dt:~10,2%" & set "Sec=%dt:~12,2%"
set "datestamp=%YYYY%%MM%%DD%" & set "timestamp=%HH%%Min%%Sec%"
set "fullstamp=%YYYY%-%MM%-%DD%_%HH%-%Min%-%Sec%"
rem echo datestamp: "%datestamp%"
rem echo timestamp: "%timestamp%"
rem echo fullstamp: "%fullstamp%"
rem Go to script's directory
cd %~dp0
rem Read filenames if needed
set rules=%~dp0rules.json
set testcases=%~dp0testcases.csv
if not exist %rules% (
echo file not found. Type in full file name and Enter
set /p rules="Rules file: "
)
if not exist %rules% (
echo We did not find rules file: %rules%
exit /B 1
)
if not exist %testcases% (
echo testcases not found. Type in full file name and Enter
set /p testcases="Testcases file: "
)
if not exist %testcases% (
echo We did not find testcase file: %testcases%
exit /B 1
)
rem Create filename for results csv
set filename="results_%fullstamp%.csv"
rem Run
cd AppFolder
dotnet run --no-build %rules% %testcases% %filename%
move %filename% ../results/
PAUSE
问题解决了。
我在另一台服务器上安装了 Web 应用程序并遇到以下异常:
Failed to add 'C:\Windows\system32\config\systemprofile\.dotnet\tools' to the PATH environment variable. Add this directory to your PATH to use tools installed with 'dotnet tool install'.
因为我遇到了 2 个类似的异常,所以我认为问题可能出在文件夹的权限上。因此,我将服务帐户的修改权限添加到
C:\Windows\system32\config\systemprofile
解决问题的文件夹中。运行应用程序后,创建了这些新文件夹:
C:\Windows\System32\config\systemprofile\.dotnet
C:\Windows\System32\config\systemprofile\.nuget
然后我在我的产品服务器上添加了相同的权限,但对于文件夹
C:\Users\Default
剩下的问题是为什么两台服务器将 .dotnet 文件夹定位在不同的路径中?
解决方案
在我重命名我的核心应用程序 dll 后遇到了类似的问题。发现我的应用程序 DLL 不再被激活。所以我检查了里面web.config
结果忘了重命名dll。
dotnet
本身不应将任何文件写入 C:\Users\Default.dotnet\tools,因此只要可以找到应用程序,就不需要权限。
推荐阅读
- excel - 对象列表行的方法(删除或添加)失败(然后崩溃)VBA
- awk - 如何提取文档的一部分并将其保存到新文档(命令行 Mac)
- firebase - onCall firebase 云功能的 CORS 问题(GCP 防火墙规则)
- apollo - 在节点中使用阿波罗 - (无反应)
- python - 过滤布尔字段
- python - Librosa - 如何为立体声音频创建梅尔频谱图?
- scala - 类加载器在使用 foreach 时为 None 加载一个类
- powershell - 如何动态调用具有相同参数的 2 个不同的 cmdlet?(不是动态参数。)
- reactjs - 下拉状态未保留在 React 中
- python - 设置变量等于 sqlite3+Python 数据库条目